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. // 以下に必要な宣言を含めて書いてください
  15. int len = myStrlen(s);
  16. int i, j;
  17.  
  18. // 回文の長さ = 元の長さ + (元の長さ - 1) = 2*len - 1
  19. // +1 は終端文字 '\0' の分
  20. tmp = (char *)malloc(sizeof(char) * (2 * len)); // 2*len で十分(最後の+1を含む)
  21.  
  22. // 前半:元の文字列をそのままコピー
  23. for (i = 0; i < len; i++) {
  24. tmp[i] = s[i];
  25. }
  26.  
  27. // 後半:元の文字列の逆順(末尾から2文字目まで → 先頭へ)
  28. // 例: "abc" → "c" "b" の順に追加? いいえ、"ba" の順
  29. // つまり s[len-2] から s[0] までを追加
  30. for (j = 0; j < len - 1; j++) {
  31. tmp[len + j] = s[len - 2 - j];
  32. }
  33.  
  34. // 終端文字
  35. tmp[2 * len - 1] = '\0';
  36.  
  37. return tmp;
  38. }
  39.  
  40. // メイン関数はいじる必要はありません
  41. int main() {
  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 5296KB
stdin
abcd
stdout
abcd
  -> abcdcba