#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;
char *tmp
= (char *)malloc(sizeof(char) * (2 * len
+ 1)); // 元の文字列 + 逆順 + '\0'
// 先に元の文字列をコピー
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() {
char nyuryoku[1024]; // 入力
char *kaibun; // 回文を受け取る
kaibun = setPalindrome(nyuryoku);
printf("%s\n -> %s\n", nyuryoku
, kaibun
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSkgewogICAgaW50IGk7CiAgICBmb3IoaSA9IDA7IHNbaV0gIT0gJ1wwJzsgaSsrKTsKICAgIHJldHVybiBpOwp9CgpjaGFyICpzZXRQYWxpbmRyb21lKGNoYXIgc1tdKSB7CiAgICBpbnQgbGVuID0gbXlTdHJsZW4ocyk7CiAgICBpbnQgaTsKICAgIGNoYXIgKnRtcCA9IChjaGFyICopbWFsbG9jKHNpemVvZihjaGFyKSAqICgyICogbGVuICsgMSkpOyAvLyDlhYPjga7mloflrZfliJcgKyDpgIbpoIYgKyAnXDAnCgogICAgLy8g5YWI44Gr5YWD44Gu5paH5a2X5YiX44KS44Kz44OU44O8CiAgICBmb3IoaSA9IDA7IGkgPCBsZW47IGkrKykgewogICAgICAgIHRtcFtpXSA9IHNbaV07CiAgICB9CgogICAgLy8g6YCG6aCG44Gr6L+95YqgCiAgICBmb3IoaSA9IDA7IGkgPCBsZW47IGkrKykgewogICAgICAgIHRtcFtsZW4gKyBpXSA9IHNbbGVuIC0gMSAtIGldOwogICAgfQoKICAgIHRtcFsyICogbGVuXSA9ICdcMCc7IC8vIOaWh+Wtl+WIl+OBrue1guerrwogICAgcmV0dXJuIHRtcDsKfQoKaW50IG1haW4oKSB7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAvLyDlhaXlipsKICAgIGNoYXIgKmthaWJ1bjsgICAgICAgIC8vIOWbnuaWh+OCkuWPl+OBkeWPluOCiwogICAgc2NhbmYoIiVzIiwgbnl1cnlva3UpOwogICAga2FpYnVuID0gc2V0UGFsaW5kcm9tZShueXVyeW9rdSk7CiAgICBwcmludGYoIiVzXG4gIC0+ICVzXG4iLCBueXVyeW9rdSwga2FpYnVuKTsKICAgIGZyZWUoa2FpYnVuKTsKICAgIHJldHVybiAwOwp9Cgo=