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. char *tmp = (char *)malloc(sizeof(char) * (2 * size + 1));
  14. if (tmp == NULL) {
  15. return NULL; // malloc失敗時の対応
  16. }
  17.  
  18. int i;
  19. for (i = 0; i < size; i++) {
  20. tmp[i] = s[i]; // 前半:元の文字列
  21. }
  22. for (i = 0; i < size; i++) {
  23. tmp[i + size] = s[size - i - 1]; // 後半:逆順
  24. }
  25.  
  26. tmp[2 * size] = '\0'; // 終端文字
  27. return tmp;
  28. }
  29.  
  30. int main() {
  31. char nyuryoku[1024]; // 入力
  32. char *kaibun; // 回文を受け取る
  33. scanf("%s", nyuryoku);
  34. kaibun = setPalindrome(nyuryoku);
  35. printf("%s\n -> %s\n", nyuryoku, kaibun);
  36. free(kaibun);
  37. return 0;
  38. }
  39.  
Success #stdin #stdout 0.01s 5292KB
stdin
abcd
stdout
abcd
  -> abcddcba