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 i, size;
  14. char *tmp;
  15.  
  16. size = myStrlen(s);
  17. tmp = (char *)malloc(sizeof(char) * (2 * size + 1)); // +1は終端文字の分
  18.  
  19. if (tmp == NULL) {
  20. printf("ERROR\n");
  21. return NULL;
  22. }
  23.  
  24. for (i = 0; i < size; i++) {
  25. tmp[i] = s[i]; // 前半:元の文字列
  26. }
  27. for (i = 0; i < size; i++) {
  28. tmp[size + i] = s[size - i - 1]; // 後半:逆順
  29. }
  30. tmp[2 * size] = '\0'; // 終端文字
  31.  
  32. return tmp;
  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.  
Success #stdin #stdout 0s 5320KB
stdin
abcd
stdout
abcd
  -> abcddcba