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. // 回文を作成し、mallocで確保した領域に入れて返す関数
  12. char *setPalindrome(char s[]) {
  13. char *tmp;
  14. int size = myStrlen(s);
  15. int i;
  16.  
  17. tmp = (char *)malloc(sizeof(char) * (2 * size + 1));
  18. if (tmp == NULL) {
  19. printf("メモリ確保失敗\n");
  20. }
  21.  
  22. for (i = 0; i < size; i++) {
  23. tmp[i] = s[i];
  24. }
  25.  
  26. for (i = 0; i < size; i++) {
  27. tmp[size + i] = s[size - 1 - i];
  28. }
  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.  
  41. scanf("%s", nyuryoku);
  42. kaibun = setPalindrome(nyuryoku);
  43. printf("%s\n -> %s\n", nyuryoku, kaibun);
  44. free(kaibun);
  45.  
  46. return 0;
  47. }
  48.  
Success #stdin #stdout 0.01s 5272KB
stdin
abcba
stdout
abcba
  -> abcbaabcba