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. int len = myStrlen(s); // 元の文字列の長さを取得
  15. int i;
  16.  
  17. tmp = (char*)malloc(2 * len + 1);
  18. if (tmp == NULL) {
  19. printf("メモリ確保に失敗しました\n");
  20. return NULL;
  21. }
  22.  
  23. for (i = 0; i < len; i++) {
  24. tmp[i] = s[i];
  25. }
  26.  
  27.  
  28. for (i = 0; i < len; i++) {
  29. tmp[len + i] = s[len - 1 - i];
  30. }
  31.  
  32.  
  33. tmp[2 * len] = '\0';
  34.  
  35. return tmp;
  36. }
  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. }
  51.  
Success #stdin #stdout 0s 5324KB
stdin
abcd
stdout
abcd
  -> abcddcba