fork download
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3.  
  4. // 文字列の長さを返す関数
  5. int myStrlen(char s[]){
  6. int i;
  7. for(i = 0; s[i] != '\0'; i++);
  8. return i;
  9. }
  10.  
  11. // 回文を作成して返す関数
  12. // 関数の中でtmpに対してmallocして
  13. // そこに回文を代入してreturnで返しましょう
  14. char *setPalindrome(char s[]){
  15. char *tmp;
  16. int len = myStrlen(s);
  17. int i;
  18.  
  19. tmp = (char *)malloc(sizeof(char) * (2 * len + 1));
  20.  
  21. for(i = 0; i < len; i++){
  22. tmp[i] = s[i];
  23. }
  24. for(i = 0; i < len; i++){
  25. tmp[len + i] = s[len - 1 - i];
  26. }
  27.  
  28. tmp[2 * len] = '\0';
  29. return tmp;
  30. }
  31.  
  32. // メイン関数はいじる必要はありません
  33. int main(){
  34. int i;
  35. char nyuryoku[1024]; //入力
  36. char *kaibun; //回文を受け取る
  37. scanf("%s", nyuryoku);
  38. kaibun = setPalindrome(nyuryoku);
  39. printf("%s\n -> %s\n", nyuryoku, kaibun);
  40. free(kaibun);
  41. return 0;
  42. }
  43.  
  44.  
Success #stdin #stdout 0.01s 5288KB
stdin
abcd
stdout
abcd
  -> abcddcba