fork download
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4. int myStrlen(char s[])
  5. {
  6. int i;
  7. for (i = 0; s[i] != '\0'; i++)
  8. ;
  9. return i;
  10. }
  11.  
  12. // 関数の中でtmpに対してmallocして
  13. // そこに回文を代入してreturnで返しましょう
  14. char *setPalindrome(char s[])
  15. { /*s=入力した文字列*/
  16. char *tmp;
  17. // 以下に必要な宣言を含めて書いてください
  18. int i;
  19. int len = myStrlen(s);
  20. tmp = malloc(sizeof(char) * (len * 2 + 1)); // 2倍のサイズでメモリを確保
  21. if (tmp == NULL)
  22. {
  23. printf("メモリの確保に失敗しました\n");
  24. return 0;
  25. }
  26.  
  27. int y = len; // 末尾の位置を設定
  28. for (i = 0; i < len; i++)
  29. {
  30. tmp[i] = s[i];
  31. }
  32. for (int x = y - 1; x >= 0; x--)
  33. tmp[i++] = s[x];
  34. tmp[i] = '\0'; // 文字列の終端を設定
  35.  
  36. return tmp;
  37. }
  38.  
  39. // メイン関数はいじる必要はありません
  40. int main()
  41. {
  42. int i;
  43. char nyuryoku[1024]; // 入力
  44. char *kaibun; // 回文を受け取る
  45. scanf("%s", nyuryoku);
  46. kaibun = setPalindrome(nyuryoku);
  47. printf("%s\n -> %s\n", nyuryoku, kaibun);
  48. free(kaibun);
  49. return 0;
  50. }
Success #stdin #stdout 0s 5280KB
stdin
abcd
stdout
abcd
  -> abcddcba