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 len = myStrlen(s);
  16. int i, j = 0;
  17.  
  18. // 回文用の配列を確保
  19. tmp = (char *)malloc((2 * len + 1) * sizeof(char));
  20. if (tmp == NULL) {
  21. printf("メモリの割り当てに失敗しました。\n");
  22. exit(1);
  23. }
  24.  
  25. // 元の文字列をコピー
  26. for (i = 0; s[i] != '\0'; i++) {
  27. tmp[j++] = s[i];
  28. }
  29.  
  30. // 元の文字列を逆順にコピー
  31. for (i = len - 1; i >= 0; i--) {
  32. tmp[j++] = s[i];
  33. }
  34. tmp[j] = '\0'; // 文字列の終端を設定
  35.  
  36. return tmp;
  37. }
  38.  
  39. //メイン関数はいじる必要はありません
  40.  
  41. int main(){
  42. int i;
  43. char nyuryoku[1024]; //入力
  44. char *kaibun; //回文を受け取る
  45. scanf("%s",nyuryoku);
  46. kaibun = setPalindrome(nyuryoku);
  47. printf("%s\n -> %s\n",nyuryoku,kaibun);
  48. free(kaibun);
  49. return 0;
  50. }
Success #stdin #stdout 0.01s 5300KB
stdin
2 3
stdout
2
  -> 22