#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);
int i;
// 元の文字列 + 逆順の文字列 + null文字 の分だけ確保
char *tmp
= (char *)malloc((2 * len
+ 1) * sizeof(char));
if(tmp == NULL) {
return NULL; // malloc失敗時
}
// 前半:元の文字列をコピー
for(i = 0; i < len; i++) {
tmp[i] = s[i];
}
// 後半:元の文字列の逆順をコピー
for(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+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICBpbnQgaTsKICAgIGZvcihpPTA7IHNbaV0hPSdcMCc7IGkrKyk7CiAgICByZXR1cm4gaTsKfQoKLy8g5Zue5paH44KS5L2c5oiQ44GZ44KL6Zai5pWwCmNoYXIgKnNldFBhbGluZHJvbWUoY2hhciBzW10pewogICAgaW50IGxlbiA9IG15U3RybGVuKHMpOwogICAgaW50IGk7CiAgICAvLyDlhYPjga7mloflrZfliJcgKyDpgIbpoIbjga7mloflrZfliJcgKyBudWxs5paH5a2XIOOBruWIhuOBoOOBkeeiuuS/nQogICAgY2hhciAqdG1wID0gKGNoYXIgKiltYWxsb2MoKDIgKiBsZW4gKyAxKSAqIHNpemVvZihjaGFyKSk7CgogICAgaWYodG1wID09IE5VTEwpIHsKICAgICAgICByZXR1cm4gTlVMTDsgLy8gbWFsbG9j5aSx5pWX5pmCCiAgICB9CgogICAgLy8g5YmN5Y2K77ya5YWD44Gu5paH5a2X5YiX44KS44Kz44OU44O8CiAgICBmb3IoaSA9IDA7IGkgPCBsZW47IGkrKykgewogICAgICAgIHRtcFtpXSA9IHNbaV07CiAgICB9CgogICAgLy8g5b6M5Y2K77ya5YWD44Gu5paH5a2X5YiX44Gu6YCG6aCG44KS44Kz44OU44O8CiAgICBmb3IoaSA9IDA7IGkgPCBsZW47IGkrKykgewogICAgICAgIHRtcFtsZW4gKyBpXSA9IHNbbGVuIC0gMSAtIGldOwogICAgfQoKICAgIHRtcFsyICogbGVuXSA9ICdcMCc7IC8vIOe1guerr+aWh+WtlwoKICAgIHJldHVybiB0bXA7Cn0KCi8vIOODoeOCpOODs+mWouaVsOOBr+OBhOOBmOOCi+W/heimgeOBquOBlwppbnQgbWFpbigpewogICAgaW50IGk7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAvL+WFpeWKmwogICAgY2hhciAqa2FpYnVuOyAgIC8v5Zue5paH44KS5Y+X44GR5Y+W44KLCiAgICBzY2FuZigiJXMiLCBueXVyeW9rdSk7CiAgICBrYWlidW4gPSBzZXRQYWxpbmRyb21lKG55dXJ5b2t1KTsKICAgIHByaW50ZigiJXNcbiAgLT4gJXNcbiIsIG55dXJ5b2t1LCBrYWlidW4pOwogICAgZnJlZShrYWlidW4pOwogICAgcmV0dXJuIDA7Cn0K