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. char *setPalindrome(char s[]) {
  11. int len = myStrlen(s);
  12. int i;
  13. char *tmp = (char *)malloc(sizeof(char) * (2 * len + 1)); // 元の文字列 + 逆順 + '\0'
  14.  
  15. // 先に元の文字列をコピー
  16. for(i = 0; i < len; i++) {
  17. tmp[i] = s[i];
  18. }
  19.  
  20. // 逆順に追加
  21. for(i = 0; i < len; i++) {
  22. tmp[len + i] = s[len - 1 - i];
  23. }
  24.  
  25. tmp[2 * len] = '\0'; // 文字列の終端
  26. return tmp;
  27. }
  28.  
  29. int main() {
  30. char nyuryoku[1024]; // 入力
  31. char *kaibun; // 回文を受け取る
  32. scanf("%s", nyuryoku);
  33. kaibun = setPalindrome(nyuryoku);
  34. printf("%s\n -> %s\n", nyuryoku, kaibun);
  35. free(kaibun);
  36. return 0;
  37. }
  38.  
  39.  
Success #stdin #stdout 0.01s 5280KB
stdin
abcd
stdout
abcd
  -> abcddcba