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. int isPalindrome(char s[]){
  10. //関数の中だけを書き換えてください
  11. //回文になっているとき1を返す
  12. //回文になっていないとき0を返す
  13. int n,i,j;
  14. for(n=0;s[n]!='\0';n++)
  15. ;
  16. char t[n];
  17. for(i=0;i<n;i++){
  18. t[n-1-i]=s[i];
  19. }
  20. for(j=0;s[j]==t[j];j++){
  21. if(s[j]=='\0') return 1;
  22. }
  23. return 0;
  24.  
  25. }
  26.  
  27. // 関数の中でtmpに対してmallocして
  28. // そこに回文を代入してreturnで返しましょう
  29. char *setPalindrome(char s[]){
  30. char *tmp;
  31. //以下に必要な宣言を含めて書いてください
  32. int i=myStrlen(s);
  33. int j;
  34. tmp=(char*)malloc(sizeof(char)*i*2);
  35. for(j=0;j<i;j++){
  36. tmp[j]=s[j];
  37. }
  38. int k;
  39. for(j=0;k==0;j++){
  40. tmp[i+j]=tmp[i-j-2];
  41. k=isPalindrome(tmp);
  42. }
  43. return tmp;
  44.  
  45. }
  46.  
  47.  
  48. //メイン関数はいじる必要はありません
  49. int main(){
  50. int i;
  51. char nyuryoku[1024]; //入力
  52. char *kaibun; //回文を受け取る
  53. scanf("%s",nyuryoku);
  54. kaibun = setPalindrome(nyuryoku);
  55. printf("%s\n -> %s\n",nyuryoku,kaibun);
  56. free(kaibun);
  57. return 0;
  58. }
  59.  
Success #stdin #stdout 0s 5284KB
stdin
abab
stdout
abab
  -> abababa