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. int len = myStrlen(s); // 入力文字列の長さを取得
  14. int i;
  15. char *tmp;
  16.  
  17. // 動的にメモリを確保
  18. tmp = (char *)malloc((2 * len + 1) * sizeof(char));
  19. if (tmp == NULL) {
  20. printf("Memory allocation failed.\n");
  21. exit(1);
  22. }
  23.  
  24. // 元の文字列をコピー
  25. for (i = 0; i < len; i++) {
  26. tmp[i] = s[i];
  27. }
  28.  
  29. // 逆順に文字を追加
  30. for (i = 0; i < len; i++) {
  31. tmp[len + i] = s[len - 1 - i];
  32. }
  33.  
  34. // 終端文字を追加
  35. tmp[2 * len] = '\0';
  36.  
  37. return tmp;
  38. }
  39.  
  40. // メイン関数
  41. int main() {
  42. char nyuryoku[1024]; // 入力用バッファ
  43. char *kaibun; // 回文を受け取る
  44. scanf("%s", nyuryoku);
  45. kaibun = setPalindrome(nyuryoku);
  46. printf("%s\n -> %s\n", nyuryoku, kaibun);
  47. free(kaibun); // 動的メモリを解放
  48. return 0;
  49. }
  50.  
Success #stdin #stdout 0.01s 5284KB
stdin
Standard input is empty
stdout
1�
  -> 1��1