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++); // '\0' に達するまで文字を数える
  8. return i; // 文字数を返す
  9. }
  10.  
  11. // 回文を作成する関数
  12. char *setPalindrome(char s[]) {
  13. int length = myStrlen(s); // 入力文字列の長さを取得
  14. int i, j;
  15.  
  16. // 回文を作るために必要なメモリを確保
  17. char *tmp = (char *)malloc(sizeof(char) * (2 * length + 1)); // 2倍の長さ + 終端文字の '\0' のため 1 を加える
  18.  
  19. // 元の文字列を tmp にコピー
  20. for (i = 0; i < length; i++) {
  21. tmp[i] = s[i];
  22. }
  23.  
  24. // 逆順の部分を追加
  25. for (i = 0; i < length - 1; i++) { // 最後の1文字は追加しない(回文になるため)
  26. tmp[length + i] = s[length - 2 - i]; // 元の文字列の末尾から逆順に追加
  27. }
  28.  
  29. tmp[2 * length - 1] = '\0'; // 終端文字を追加
  30.  
  31. return tmp; // 回文文字列を返す
  32. }
  33.  
  34. // メイン関数
  35. int main() {
  36. char nyuryoku[1024]; // 入力用文字列
  37. char *kaibun; // 回文を受け取る
  38.  
  39. // 入力を受け取る
  40. scanf("%s", nyuryoku);
  41.  
  42. // 回文を作成
  43. kaibun = setPalindrome(nyuryoku);
  44.  
  45. // 結果を表示
  46. printf("%s\n -> %s\n", nyuryoku, kaibun);
  47.  
  48. // 動的に確保したメモリを解放
  49. free(kaibun);
  50.  
  51. return 0;
  52. }
  53.  
Success #stdin #stdout 0.01s 5280KB
stdin
abcd
stdout
abcd
  -> abcdcba