fork(1) 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. int len = myStrlen(s);
  13. // 回文を格納するためのメモリを確保
  14. char *tmp = (char*)malloc(sizeof(char) * (len * 2 + 1));
  15.  
  16. /*if (tmp == NULL) { // メモリ確保が失敗した場合
  17.   printf("Memory allocation failed.\n");
  18.   return NULL;
  19.   }*/
  20.  
  21. // 元の文字列をtmpにコピー
  22. for (int i = 0; i < len; i++) {
  23. tmp[i] = s[i];
  24. }
  25.  
  26. // 反転した文字列をtmpの後ろに追加
  27. for (int i = 0; i < len; i++) {
  28. tmp[len + i] = s[len - 1 - i];
  29. }
  30.  
  31. tmp[len * 2] = '\0'; // 文字列の終端を追加
  32.  
  33. return tmp;
  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 0.01s 5284KB
stdin
abcd
stdout
abcd
  -> abcddcba