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 len = myStrlen(s);
  13. int i;
  14. // 元の文字列 + 逆順の文字列 + null文字 の分だけ確保
  15. char *tmp = (char *)malloc((2 * len + 1) * sizeof(char));
  16.  
  17. if(tmp == NULL) {
  18. return NULL; // malloc失敗時
  19. }
  20.  
  21. // 前半:元の文字列をコピー
  22. for(i = 0; i < len; i++) {
  23. tmp[i] = s[i];
  24. }
  25.  
  26. // 後半:元の文字列の逆順をコピー
  27. for(i = 0; i < len; i++) {
  28. tmp[len + i] = s[len - 1 - i];
  29. }
  30.  
  31. tmp[2 * len] = '\0'; // 終端文字
  32.  
  33. return tmp;
  34. }
  35.  
  36. // メイン関数はいじる必要なし
  37. int main(){
  38. int i;
  39. char nyuryoku[1024]; //入力
  40. char *kaibun; //回文を受け取る
  41. scanf("%s", nyuryoku);
  42. kaibun = setPalindrome(nyuryoku);
  43. printf("%s\n -> %s\n", nyuryoku, kaibun);
  44. free(kaibun);
  45. return 0;
  46. }
  47.  
  48.  
Success #stdin #stdout 0s 5288KB
stdin
abcde
stdout
abcde
  -> abcdeedcba