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. char *tmp;
  14. //以下に必要な宣言を含めて書いてください
  15. int k=1,m = myStrlen(s);
  16. for (int i = 0; i < m; i++) {
  17. // 前半部分 s[0:i] と後半部分 s[m-i:m] が一致するかを確認
  18. int match = 1;
  19. for (int j = 0; j < m - i; j++) {
  20. if (s[j] != s[m - 1 - j]) {
  21. match = 0;
  22. break;
  23. }
  24. }
  25.  
  26. // 完全に一致した場合
  27. if (match) {
  28. break;
  29. }
  30. }
  31. tmp = (char *)malloc(sizeof(char)* (2*m+1));
  32. if (tmp == NULL) {
  33. printf("ERROR\n");
  34. return 0;}
  35. for (int i = 0; i < m; i++) {
  36. tmp[i] = s[i];}
  37.  
  38. for (int i = 0; i < m; i++) {
  39. tmp[m+i] = s[m-1-i];}
  40. tmp[2 * m]='\0';
  41. return tmp;
  42. }
  43. //メイン関数はいじる必要はありません
  44. int main(){
  45. int i;
  46. char nyuryoku[1024]; //入力
  47. char *kaibun; //回文を受け取る
  48. scanf("%s",nyuryoku);
  49. kaibun = setPalindrome(nyuryoku);
  50. printf("%s\n -> %s\n",nyuryoku,kaibun);
  51. free(kaibun);
  52. return 0;
  53. }
  54.  
Success #stdin #stdout 0s 5276KB
stdin
aba
stdout
aba
  -> abaaba