#include <stdio.h>
#include <stdlib.h>
int myStrlen(char s[]){
int i;
for(i=0;s[i]!='\0';i++);
return i;
}
// 関数の中でtmpに対してmallocして
// そこに回文を代入してreturnで返しましょう
char *setPalindrome(char s[]){
char *tmp;
//以下に必要な宣言を含めて書いてください
int i, len = myStrlen(s);
// 元の文字列の2倍の長さ + 終端文字('\0')分のメモリを確保
tmp
= (char *)malloc(sizeof(char) * (len
* 2 + 1));
for (i = 0; i < len; i++) {
tmp[i] = s[i]; // 前半部分にコピー
tmp[2 * len - 1 - i] = s[i]; // 後半部分に逆順でコピー
}
tmp[2 * len] = '\0'; // 終端文字を代入
return tmp;
}
//メイン関数はいじる必要はありません
int main(){
int i;
char nyuryoku[1024]; //入力
char *kaibun; //回文を受け取る
kaibun = setPalindrome(nyuryoku);
printf("%s\n -> %s\n",nyuryoku
,kaibun
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICBpbnQgaTsKICAgIGZvcihpPTA7c1tpXSE9J1wwJztpKyspOwogICAgcmV0dXJuIGk7Cn0KCi8vIOmWouaVsOOBruS4reOBp3RtcOOBq+WvvuOBl+OBpm1hbGxvY+OBl+OBpgovLyDjgZ3jgZPjgavlm57mlofjgpLku6PlhaXjgZfjgaZyZXR1cm7jgafov5TjgZfjgb7jgZfjgofjgYYKY2hhciAqc2V0UGFsaW5kcm9tZShjaGFyIHNbXSl7CgljaGFyICp0bXA7CgkvL+S7peS4i+OBq+W/heimgeOBquWuo+iogOOCkuWQq+OCgeOBpuabuOOBhOOBpuOBj+OBoOOBleOBhAoJaW50IGksIGxlbiA9IG15U3RybGVuKHMpOwoKCS8vIOWFg+OBruaWh+Wtl+WIl+OBrjLlgI3jga7plbfjgZUgKyDntYLnq6/mloflrZcoJ1wwJynliIbjga7jg6Hjg6Ljg6rjgpLnorrkv50KCXRtcCA9IChjaGFyICopbWFsbG9jKHNpemVvZihjaGFyKSAqIChsZW4gKiAyICsgMSkpOwoKCWZvciAoaSA9IDA7IGkgPCBsZW47IGkrKykgewoJCXRtcFtpXSA9IHNbaV07ICAgICAgICAgICAgLy8g5YmN5Y2K6YOo5YiG44Gr44Kz44OU44O8CgkJdG1wWzIgKiBsZW4gLSAxIC0gaV0gPSBzW2ldOyAvLyDlvozljYrpg6jliIbjgavpgIbpoIbjgafjgrPjg5Tjg7wKCX0KCgl0bXBbMiAqIGxlbl0gPSAnXDAnOyAvLyDntYLnq6/mloflrZfjgpLku6PlhaUKCXJldHVybiB0bXA7Cn0KCgovL+ODoeOCpOODs+mWouaVsOOBr+OBhOOBmOOCi+W/heimgeOBr+OBguOCiuOBvuOBm+OCkwppbnQgbWFpbigpewogICAgaW50IGk7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAvL+WFpeWKmwogICAgY2hhciAqa2FpYnVuOyAgIC8v5Zue5paH44KS5Y+X44GR5Y+W44KLCiAgICBzY2FuZigiJXMiLG55dXJ5b2t1KTsKICAgIGthaWJ1biA9IHNldFBhbGluZHJvbWUobnl1cnlva3UpOwogICAgcHJpbnRmKCIlc1xuICAtPiAlc1xuIixueXVyeW9rdSxrYWlidW4pOwogICAgZnJlZShrYWlidW4pOwogICAgcmV0dXJuIDA7Cn0K