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. // 回文を作成する関数
  11. char *setPalindrome(char s[]) {
  12. int len = myStrlen(s);
  13. int i, j;
  14. char *tmp;
  15.  
  16. // メモリ確保: オリジナル文字列 + 逆順文字列 + null 終端
  17. tmp = (char*)malloc(sizeof(char) * (2 * len + 1));
  18.  
  19. // オリジナル文字列をtmpにコピー
  20. for (i = 0; i < len; i++) {
  21. tmp[i] = s[i];
  22. }
  23.  
  24. // 逆順文字列をtmpにコピー
  25. for (j = 0; j < len; j++) {
  26. tmp[len + j] = s[len - j - 1]; // 正しく逆順にコピー
  27. }
  28.  
  29. // null 終端を追加
  30. tmp[2 * len] = '\0';
  31.  
  32. return tmp;
  33. }
  34.  
  35. // メイン関数は変更不要
  36. int main() {
  37. char nyuryoku[1024]; // 入力用の配列
  38. char *kaibun; // 回文を受け取るポインタ
  39.  
  40. scanf("%s", nyuryoku); // 文字列の入力
  41. kaibun = setPalindrome(nyuryoku); // 回文を生成
  42.  
  43. printf("%s\n -> %s\n", nyuryoku, kaibun); // 結果を表示
  44.  
  45. free(kaibun); // 確保したメモリを解放
  46. return 0;
  47. }
  48.  
Success #stdin #stdout 0s 5284KB
stdin
abc
stdout
abc
  -> abccba