fork download
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4. int myStrlen(char s[]){
  5. int i;
  6. for(i=0;s[i]!='\0';i++);
  7. return i;
  8. }
  9.  
  10. // 関数の中でtmpに対してmallocして
  11. // そこに回文を代入してreturnで返しましょう
  12. char *setPalindrome(char s[]){
  13. char *tmp;
  14. int len = myStrlen(s);
  15. int i;
  16.  
  17. // 回文の長さは元の文字列の2倍+終端文字分
  18. tmp = (char *)malloc(sizeof(char) * (len * 2 + 1));
  19.  
  20. // 元の文字列をコピー
  21. for(i = 0; i < len; i++){
  22. tmp[i] = s[i];
  23. }
  24.  
  25. // 逆順の文字列を連結
  26. for(i = 0; i < len; i++){
  27. tmp[len + i] = s[len - 1 - i];
  28. }
  29.  
  30. // 終端文字を追加
  31. tmp[len * 2] = '\0';
  32.  
  33. return tmp;
  34. }
  35.  
  36.  
  37. //メイン関数はいじる必要はありません
  38. int main(){
  39. // int i;
  40. char nyuryoku[1024]; //入力
  41. char *kaibun; //回文を受け取る
  42. scanf("%s",nyuryoku);
  43. kaibun = setPalindrome(nyuryoku);
  44. printf("%s\n -> %s\n",nyuryoku,kaibun);
  45. free(kaibun);
  46. return 0;
  47. }
Success #stdin #stdout 0s 5320KB
stdin
abcd
stdout
abcd
  -> abcddcba