#include <stdio.h>
#include <stdlib.h>
int myStrlen(char s[]){
int i;
for (i = 0; s[i] != '\0'; i++);
return i;
}
char *setPalindrome(char s[]) {
int len = myStrlen(s);
char *tmp
= (char *)malloc(sizeof(char) * (2 * len
+ 1)); // 回文分 + 終端
if (tmp == NULL) {
}
// 元の文字列をコピー
for (int i = 0; i < len; i++) {
tmp[i] = s[i];
}
// 逆順にして末尾に追加
for (int i = 0; i < len; i++) {
tmp[len + i] = s[len - 1 - 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+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICAgaW50IGk7CiAgICBmb3IgKGkgPSAwOyBzW2ldICE9ICdcMCc7IGkrKyk7CiAgICByZXR1cm4gaTsKfQoKY2hhciAqc2V0UGFsaW5kcm9tZShjaGFyIHNbXSkgewogICAgaW50IGxlbiA9IG15U3RybGVuKHMpOwogICAgY2hhciAqdG1wID0gKGNoYXIgKiltYWxsb2Moc2l6ZW9mKGNoYXIpICogKDIgKiBsZW4gKyAxKSk7ICAvLyDlm57mlofliIYgKyDntYLnq68KCiAgICBpZiAodG1wID09IE5VTEwpIHsKICAgICAgICBwcmludGYoIuODoeODouODqueiuuS/neOBq+WkseaVl+OBl+OBvuOBl+OBn1xuIik7CiAgICAgICAgZXhpdCgxKTsKICAgIH0KCiAgICAvLyDlhYPjga7mloflrZfliJfjgpLjgrPjg5Tjg7wKICAgIGZvciAoaW50IGkgPSAwOyBpIDwgbGVuOyBpKyspIHsKICAgICAgICB0bXBbaV0gPSBzW2ldOwogICAgfQoKICAgIC8vIOmAhumghuOBq+OBl+OBpuacq+WwvuOBq+i/veWKoAogICAgZm9yIChpbnQgaSA9IDA7IGkgPCBsZW47IGkrKykgewogICAgICAgIHRtcFtsZW4gKyBpXSA9IHNbbGVuIC0gMSAtIGldOwogICAgfQoKICAgIHRtcFsyICogbGVuXSA9ICdcMCc7ICAvLyDntYLnq6/mloflrZcKICAgIHJldHVybiB0bXA7IAp9CgoKLy/jg6HjgqTjg7PplqLmlbDjga/jgYTjgZjjgovlv4XopoHjga/jgYLjgorjgb7jgZvjgpMKaW50IG1haW4oKXsKICAgIGludCBpOwogICAgY2hhciBueXVyeW9rdVsxMDI0XTsgLy/lhaXlipsKICAgIGNoYXIgKmthaWJ1bjsgICAvL+WbnuaWh+OCkuWPl+OBkeWPluOCiwogICAgc2NhbmYoIiVzIixueXVyeW9rdSk7CiAgICBrYWlidW4gPSBzZXRQYWxpbmRyb21lKG55dXJ5b2t1KTsKICAgIHByaW50ZigiJXNcbiAgLT4gJXNcbiIsbnl1cnlva3Usa2FpYnVuKTsKICAgIGZyZWUoa2FpYnVuKTsKICAgIHJldHVybiAwOwp9Cg==