fork download
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #define rep(i, n) for (int i = 0; i < (int)(n); i++)
  4.  
  5. int myStrlen(char s[]){
  6. int i;
  7. for(i=0;s[i]!='\0';i++);
  8. return i;
  9. }
  10.  
  11. int isPalindrome(char s[]){
  12. int ans=1,ss = myStrlen(s);
  13. rep(i,ss){
  14. if(s[i] != s[ss-i-1]) ans = 0;
  15. }
  16. return ans;
  17. }
  18.  
  19. // 関数の中でtmpに対してmallocして
  20. // そこに回文を代入してreturnで返しましょう
  21. char *setPalindrome(char s[]){
  22. char *tmp;
  23. //以下に必要な宣言を含めて書いてください
  24. int ss= myStrlen(s);
  25. tmp = (char*)malloc(sizeof(char)*ss*2+1);
  26. for(int i=0;i<ss;i++){
  27. tmp[i] = s[i];
  28. }
  29. tmp[ss] = '\0';
  30. if(isPalindrome(tmp)) return tmp;
  31. for(int i=0; i<ss; i++){
  32. tmp[ss] = s[i];
  33. tmp[ss+i+1] = '\0';
  34. if(isPalindrome(tmp)) break;
  35. for(int j=ss+i;j>=ss;j--){
  36. tmp[j+1] = tmp[j];
  37. }
  38. }
  39. return tmp;
  40. }
  41.  
  42.  
  43. //メイン関数はいじる必要はありません
  44. int main(){
  45. int i;
  46. char nyuryoku[1024]; //入力
  47. char *kaibun; //回文を受け取る
  48. scanf("%s",nyuryoku);
  49. kaibun = setPalindrome(nyuryoku);
  50. printf("%s\n -> %s\n",nyuryoku,kaibun);
  51. free(kaibun);
  52. return 0;
  53. }
  54.  
Success #stdin #stdout 0s 5324KB
stdin
abcd
stdout
abcd
  -> abcdcba