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