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 size = myStrlen(s);
  13.  
  14. // メモリを確保: 回文の長さは 2 * size + 1 (null terminator)
  15. char *tmp = (char *)malloc(sizeof(char) * (2 * size + 1));
  16.  
  17. if (tmp == NULL) {
  18. // メモリ確保に失敗した場合はエラーメッセージを出して終了
  19. printf("Memory allocation failed.\n");
  20. exit(1);
  21. }
  22.  
  23. // 元の文字列を tmp にコピー
  24. for (int i = 0; i < size; i++) {
  25. tmp[i] = s[i];
  26. }
  27. for (int j =size; j > 0; j--) {
  28. tmp[j] = s[j];
  29. }
  30. tmp[2 * size] = '\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 0s 5280KB
stdin
abcd
stdout
abcd
  -> abcd