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