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. int len = myStrlen(s);
  14. int i;
  15.  
  16. // mallocで2倍の長さ + '\0' の分を確保
  17. char *tmp = (char *)malloc((2 * len + 1) * sizeof(char));
  18. if (tmp == NULL) {
  19. // mallocに失敗した場合
  20. return NULL;
  21. }
  22.  
  23. // 元の文字列をコピー(前半)
  24. for (i = 0; i < len; i++) {
  25. tmp[i] = s[i];
  26. }
  27.  
  28. // 逆順にしてコピー(後半)
  29. for (i = 0; i < len; i++) {
  30. tmp[len + i] = s[len - 1 - i];
  31. }
  32.  
  33. // null終端
  34. tmp[2 * len] = '\0';
  35.  
  36. return tmp;
  37. }
  38.  
  39. // メイン関数はいじる必要はありません
  40. int main(){
  41. int i;
  42. char nyuryoku[1024]; //入力
  43. char *kaibun; //回文を受け取る
  44. scanf("%s",nyuryoku);
  45. kaibun = setPalindrome(nyuryoku);
  46. printf("%s\n -> %s\n",nyuryoku,kaibun);
  47. free(kaibun);
  48. return 0;
  49. }
  50.  
Success #stdin #stdout 0.01s 5288KB
stdin
Standard input is empty
stdout
1�K��
  -> 1�K����K�1