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