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 m = myStrlen(s);
  16. tmp = (char *)malloc(sizeof(char)* (2*m+1));
  17. if (tmp == NULL) {
  18. printf("ERROR\n");
  19. return 0;}
  20. for (int i = 0; i < m; i++) {
  21. tmp[i] = s[i];}
  22. if (m/2==0){
  23. for (int i = 0; i < m; i++) {
  24. tmp[m+i] = s[m-1-i];}
  25. tmp[2 * m]='\0';
  26. }
  27. else{
  28. for (int i = 0; i < m; i++) {
  29. tmp[m+i-1] = s[m-1-i];}
  30. tmp[2 * m]='\0';
  31. }
  32. return tmp;
  33. }
  34. //メイン関数はいじる必要はありません
  35. int main(){
  36. int i;
  37. char nyuryoku[1024]; //入力
  38. char *kaibun; //回文を受け取る
  39. scanf("%s",nyuryoku);
  40. kaibun = setPalindrome(nyuryoku);
  41. printf("%s\n -> %s\n",nyuryoku,kaibun);
  42. free(kaibun);
  43. return 0;
  44. }
  45.  
Success #stdin #stdout 0s 5280KB
stdin
fdw
stdout
fdw
  -> fdwdf