fork(1) 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 total_len = 2 * len;
  14. char *tmp = (char *)malloc((total_len + 1) * sizeof(char)); // 終端文字分のメモリを確保
  15.  
  16. if (tmp == NULL) {
  17. fprintf(stderr, "Memory allocation failed\n");
  18. return NULL;
  19. }
  20.  
  21. // 文字列を結合して回文を作成する
  22. for (int i = 0; i < len; i++) {
  23. tmp[i] = s[i]; // 元の文字列をコピー
  24. tmp[total_len - 1 - i] = s[i]; // 逆順にコピー
  25. }
  26. tmp[total_len] = '\0'; // 終端文字
  27.  
  28. return tmp;
  29. }
  30.  
  31. int main() {
  32. int i;
  33. char nyuryoku[1024]; // 入力
  34. char *kaibun; // 回文を受け取る
  35. scanf("%s", nyuryoku);
  36. kaibun = setPalindrome(nyuryoku);
  37. printf("%s\n -> %s\n", nyuryoku, kaibun);
  38. free(kaibun);
  39. return 0;
  40. }
  41.  
Success #stdin #stdout 0.01s 5280KB
stdin
abcd
stdout
abcd
  -> abcddcba