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