fork download
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4. // 文字列の長さを求める関数
  5. int myStrlen(char s[]){
  6. int i;
  7. for(i=0; s[i] != '\0'; i++);
  8. return i;
  9. }
  10.  
  11. // 回文を生成する関数
  12. char *setPalindrome(char s[]){
  13. char *tmp;
  14. int i, len;
  15. len = myStrlen(s);
  16.  
  17. // 回文の長さは元の文字列の長さ * 2 - 1 (中間の文字は重複)
  18. tmp = (char *)malloc((2 * len) * sizeof(char)); // メモリ確保
  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 - i - 1];
  28. }
  29.  
  30. tmp[2 * len] = '\0'; // 終端文字を追加
  31.  
  32. return tmp;
  33. }
  34.  
  35. int main(){
  36. int i;
  37. char nyuryoku[1024];
  38. char *kaibun;
  39.  
  40. // 入力を受け取る
  41. scanf("%s", nyuryoku);
  42.  
  43. // 回文を生成
  44. kaibun = setPalindrome(nyuryoku);
  45.  
  46. // 結果を出力
  47. printf("%s\n -> %s\n", nyuryoku, kaibun);
  48.  
  49. // 動的メモリの解放
  50. free(kaibun);
  51.  
  52. return 0;
  53. }
  54.  
Success #stdin #stdout 0.01s 5280KB
stdin
abcd
stdout
abcd
  -> abcddcba