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. int i;
  15. int len;
  16.  
  17. len = myStrlen(s);
  18.  
  19. // 元の文字列 len 個 + 逆順 len 個 + 終端文字 '\0' の分
  20. tmp = (char *)malloc(sizeof(char) * (len * 2 + 1));
  21.  
  22. if(tmp == NULL){
  23. printf("ERROR\n");
  24. return NULL;
  25. }
  26.  
  27. // 前半に元の文字列を入れる
  28. for(i=0;i<len;i++){
  29. tmp[i] = s[i];
  30. }
  31.  
  32. // 後半に逆順の文字列を入れる
  33. for(i=0;i<len;i++){
  34. tmp[len + i] = s[len - 1 - i];
  35. }
  36.  
  37. // 最後に終端文字を入れる
  38. tmp[len * 2] = '\0';
  39.  
  40. return tmp;
  41. }
  42.  
  43.  
  44. //メイン関数はいじる必要はありません
  45. int main(){
  46. int i;
  47. char nyuryoku[1024]; //入力
  48. char *kaibun; //回文を受け取る
  49.  
  50. scanf("%s",nyuryoku);
  51.  
  52. kaibun = setPalindrome(nyuryoku);
  53.  
  54. printf("%s\n -> %s\n",nyuryoku,kaibun);
  55.  
  56. free(kaibun);
  57.  
  58. return 0;
  59. }
  60.  
Success #stdin #stdout 0.01s 5332KB
stdin
abcd
stdout
abcd
  -> abcddcba