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. // 関数の中でtmpに対してmallocして
  11. // そこに回文を代入してreturnで返しましょう
  12. char *setPalindrome(char s[]){
  13. char *tmp;
  14. //以下に必要な宣言を含めて書いてください
  15. int size;
  16. size=myStrlen(s);
  17. tmp = (char *)malloc(sizeof(char)*(2*size+1)); ///char文字のマロック 回文だから*2
  18. if(tmp == NULL){
  19. printf("ERROR\n");
  20. return NULL; //void型なので何も返さず終了 おまじない
  21. }
  22. int i;
  23. for(i=0;i<size;i++) tmp[i] = s[i]; ///前半
  24. for(i=0;i<size;i++) tmp[i+size] = s[size-i-1]; ///後半
  25. tmp[2*size] = '\0'; ///終端文字
  26. return tmp; ///回文返す
  27. }
  28.  
  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 5300KB
stdin
abcd
stdout
abcd
  -> abcddcba