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. // 回文を作る関数
  11. char *setPalindrome(char s[]){
  12. char *tmp;
  13. int len = myStrlen(s);
  14. int i;
  15.  
  16. // 元文字列 + 逆順 + 終端文字
  17. tmp = (char *)malloc((len * 2 + 1) * sizeof(char));
  18.  
  19. // 前半コピー
  20. for(i = 0; i < len; i++){
  21. tmp[i] = s[i];
  22. }
  23.  
  24. // 後半に逆順を追加
  25. for(i = 0; i < len; i++){
  26. tmp[len + i] = s[len - 1 - i];
  27. }
  28.  
  29. // 文字列の終端
  30. tmp[len * 2] = '\0';
  31.  
  32. return tmp;
  33. }
  34.  
  35. // メイン関数
  36. int main(){
  37. char nyuryoku[1024]; // 入力
  38. char *kaibun; // 回文
  39.  
  40. scanf("%s", nyuryoku);
  41. kaibun = setPalindrome(nyuryoku);
  42.  
  43. printf("%s\n -> %s\n", nyuryoku, kaibun);
  44.  
  45. free(kaibun); // メモリ解放
  46. return 0;
  47. }
  48.  
Success #stdin #stdout 0.01s 5324KB
stdin
abcd
stdout
abcd
  -> abcddcba