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 counter = myStrlen(s);
  16. int a = 0;
  17.  
  18. tmp = (char *)malloc(sizeof(char)*counter*2);
  19.  
  20. for(int i = 0; i < counter; i++)
  21. {
  22. tmp[i] = s[i];
  23. }
  24.  
  25. for(int i = counter - 1; i >= 0; i--)
  26. {
  27. tmp[counter + a] += s[i];
  28. a++;
  29. }
  30.  
  31. return tmp;
  32. }
  33.  
  34.  
  35. //メイン関数はいじる必要はありません
  36. int main(){
  37. int i;
  38. char nyuryoku[1024]; //入力
  39. char *kaibun; //回文を受け取る
  40. scanf("%s",nyuryoku);
  41. kaibun = setPalindrome(nyuryoku);
  42. printf("%s\n -> %s\n",nyuryoku,kaibun);
  43. free(kaibun);
  44. return 0;
  45. }
  46.  
  47. /*
  48. 方針
  49. ➔文字数を数え、半分の位置から回文になりかけているかチェック➔足りていない部分を足す
  50. */
Success #stdin #stdout 0s 5288KB
stdin
abcd
stdout
abcd
  -> abcddcba