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