#include <stdio.h>
#include <stdlib.h>
#include <string.h>
int myStrlen(char s[]) {
int i;
for (i = 0; s[i] != '\0'; i++);
return i;
}
char *setPalindrome(char s[]) {
int len = myStrlen(s);
// 回文の長さは len + (len - 1) + 1 (for '\0')
char *tmp
= (char *)malloc((2 * len
) * sizeof(char)); if (tmp == NULL) {
fprintf(stderr
, "Memory allocation failed\n"); }
// 元の文字列をコピー
// 逆順にした文字列を追加
for (int i = 0; i < len - 1; i++) {
tmp[len + i] = s[len - i - 2];
}
tmp[2 * len - 1] = '\0'; // 終端文字
return tmp;
}
int main() {
char nyuryoku[1024]; // 入力
char *kaibun; // 回文を受け取る
kaibun = setPalindrome(nyuryoku);
printf("%s\n -> %s\n", nyuryoku
, kaibun
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KI2luY2x1ZGUgPHN0cmluZy5oPgoKaW50IG15U3RybGVuKGNoYXIgc1tdKSB7CiAgICBpbnQgaTsKICAgIGZvciAoaSA9IDA7IHNbaV0gIT0gJ1wwJzsgaSsrKTsKICAgIHJldHVybiBpOwp9CgpjaGFyICpzZXRQYWxpbmRyb21lKGNoYXIgc1tdKSB7CiAgICBpbnQgbGVuID0gbXlTdHJsZW4ocyk7CiAgICAvLyDlm57mlofjga7plbfjgZXjga8gbGVuICsgKGxlbiAtIDEpICsgMSAoZm9yICdcMCcpCiAgICBjaGFyICp0bXAgPSAoY2hhciAqKW1hbGxvYygoMiAqIGxlbikgKiBzaXplb2YoY2hhcikpOwogICAgaWYgKHRtcCA9PSBOVUxMKSB7CiAgICAgICAgZnByaW50ZihzdGRlcnIsICJNZW1vcnkgYWxsb2NhdGlvbiBmYWlsZWRcbiIpOwogICAgICAgIGV4aXQoMSk7CiAgICB9CgogICAgLy8g5YWD44Gu5paH5a2X5YiX44KS44Kz44OU44O8CiAgICBzdHJjcHkodG1wLCBzKTsKCiAgICAvLyDpgIbpoIbjgavjgZfjgZ/mloflrZfliJfjgpLov73liqAKICAgIGZvciAoaW50IGkgPSAwOyBpIDwgbGVuIC0gMTsgaSsrKSB7CiAgICAgICAgdG1wW2xlbiArIGldID0gc1tsZW4gLSBpIC0gMl07CiAgICB9CiAgICB0bXBbMiAqIGxlbiAtIDFdID0gJ1wwJzsgLy8g57WC56uv5paH5a2XCgogICAgcmV0dXJuIHRtcDsKfQoKaW50IG1haW4oKSB7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAvLyDlhaXlipsKICAgIGNoYXIgKmthaWJ1bjsgICAgICAgIC8vIOWbnuaWh+OCkuWPl+OBkeWPluOCiwogICAgc2NhbmYoIiVzIiwgbnl1cnlva3UpOwogICAga2FpYnVuID0gc2V0UGFsaW5kcm9tZShueXVyeW9rdSk7CiAgICBwcmludGYoIiVzXG4gIC0+ICVzXG4iLCBueXVyeW9rdSwga2FpYnVuKTsKICAgIGZyZWUoa2FpYnVuKTsKICAgIHJldHVybiAwOwp9