#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[]){
char *tmp;
int len = myStrlen(s);
int i;
// 元文字列 + 逆順 + 終端文字
tmp
= (char *)malloc((len
* 2 + 1) * sizeof(char));
// 前半コピー
for(i = 0; i < len; i++){
tmp[i] = s[i];
}
// 後半に逆順を追加
for(i = 0; i < len; i++){
tmp[len + i] = s[len - 1 - i];
}
// 文字列の終端
tmp[len * 2] = '\0';
return tmp;
}
// メイン関数
int main(){
char nyuryoku[1024]; // 入力
char *kaibun; // 回文
kaibun = setPalindrome(nyuryoku);
printf("%s\n -> %s\n", nyuryoku
, kaibun
);
return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICBpbnQgaTsKICAgIGZvcihpID0gMDsgc1tpXSAhPSAnXDAnOyBpKyspOwogICAgcmV0dXJuIGk7Cn0KCi8vIOWbnuaWh+OCkuS9nOOCi+mWouaVsApjaGFyICpzZXRQYWxpbmRyb21lKGNoYXIgc1tdKXsKICAgIGNoYXIgKnRtcDsKICAgIGludCBsZW4gPSBteVN0cmxlbihzKTsKICAgIGludCBpOwoKICAgIC8vIOWFg+aWh+Wtl+WIlyArIOmAhumghiArIOe1guerr+aWh+WtlwogICAgdG1wID0gKGNoYXIgKiltYWxsb2MoKGxlbiAqIDIgKyAxKSAqIHNpemVvZihjaGFyKSk7CgogICAgLy8g5YmN5Y2K44Kz44OU44O8CiAgICBmb3IoaSA9IDA7IGkgPCBsZW47IGkrKyl7CiAgICAgICAgdG1wW2ldID0gc1tpXTsKICAgIH0KCiAgICAvLyDlvozljYrjgavpgIbpoIbjgpLov73liqAKICAgIGZvcihpID0gMDsgaSA8IGxlbjsgaSsrKXsKICAgICAgICB0bXBbbGVuICsgaV0gPSBzW2xlbiAtIDEgLSBpXTsKICAgIH0KCiAgICAvLyDmloflrZfliJfjga7ntYLnq68KICAgIHRtcFtsZW4gKiAyXSA9ICdcMCc7CgogICAgcmV0dXJuIHRtcDsKfQoKLy8g44Oh44Kk44Oz6Zai5pWwCmludCBtYWluKCl7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAvLyDlhaXlipsKICAgIGNoYXIgKmthaWJ1bjsgICAgICAgIC8vIOWbnuaWhwoKICAgIHNjYW5mKCIlcyIsIG55dXJ5b2t1KTsKICAgIGthaWJ1biA9IHNldFBhbGluZHJvbWUobnl1cnlva3UpOwoKICAgIHByaW50ZigiJXNcbiAgLT4gJXNcbiIsIG55dXJ5b2t1LCBrYWlidW4pOwoKICAgIGZyZWUoa2FpYnVuKTsgLy8g44Oh44Oi44Oq6Kej5pS+CiAgICByZXR1cm4gMDsKfQo=