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. int size = myStrlen(s);
  17.  
  18. tmp = (char*)malloc(sizeof(char)*(size * 2));
  19.  
  20. for(i=0;i<size;i++){ // tmpにsの文を入れる
  21. tmp[i] = s[i];
  22. }
  23.  
  24. for(j=0;j<size-1;j++){
  25. for(k=0;k<size-1+j;k++){
  26. if(tmp[k] != tmp[size-1 + j-k]) //回文の判定
  27. break;
  28. }
  29. if(k>=size-1+j){ //回文であれば終了、回文でなければ続行
  30. tmp[size+j] = '\0';
  31. return tmp;
  32. }
  33. tmp[size+j] = s[size-j-2]; //sの後ろから2番目の値から代入
  34. }
  35. }
  36.  
  37.  
  38. //メイン関数はいじる必要はありません
  39. int main(){
  40. int i;
  41. char nyuryoku[1024]; //入力
  42. char *kaibun; //回文を受け取る
  43. scanf("%s",nyuryoku);
  44. kaibun = setPalindrome(nyuryoku);
  45. printf("%s\n -> %s\n",nyuryoku,kaibun);
  46. free(kaibun);
  47. return 0;
  48. }
  49.  
Success #stdin #stdout 0s 5300KB
stdin
abab
stdout
abab
  -> ababa