#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 i, len = myStrlen(s);
if (len % 2 != 0) {
return NULL;
}
char *tmp
= (char *)malloc(sizeof(char) * (2 * len
+ 1)); if (tmp == NULL) {
return NULL;
}
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);
if (kaibun == NULL) {
printf("%s\n -> (null)\n", nyuryoku
); } else {
printf("%s\n -> %s\n", nyuryoku
, kaibun
); }
return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSkgewogICAgaW50IGk7CiAgICBmb3IgKGkgPSAwOyBzW2ldICE9ICdcMCc7IGkrKyk7CiAgICByZXR1cm4gaTsKfQoKY2hhciAqc2V0UGFsaW5kcm9tZShjaGFyIHNbXSkgewogICAgaW50IGksIGxlbiA9IG15U3RybGVuKHMpOwogICAKICAgIGlmIChsZW4gJSAyICE9IDApIHsKICAgICAgICByZXR1cm4gTlVMTDsKICAgIH0KCiAgICBjaGFyICp0bXAgPSAoY2hhciAqKW1hbGxvYyhzaXplb2YoY2hhcikgKiAoMiAqIGxlbiArIDEpKTsKICAgIGlmICh0bXAgPT0gTlVMTCkgewogICAgICAgIHJldHVybiBOVUxMOwogICAgfQoKICAgIGZvciAoaSA9IDA7IGkgPCBsZW47IGkrKykgewogICAgICAgIHRtcFtpXSA9IHNbaV07CiAgICB9CgogICAgZm9yIChpID0gMDsgaSA8IGxlbjsgaSsrKSB7CiAgICAgICAgdG1wW2xlbiArIGldID0gc1tsZW4gLSAxIC0gaV07CiAgICB9CgogICAgdG1wWzIgKiBsZW5dID0gJ1wwJzsKICAgIHJldHVybiB0bXA7Cn0KCmludCBtYWluKCkgewogICAgY2hhciBueXVyeW9rdVsxMDI0XTsKICAgIGNoYXIgKmthaWJ1bjsKCiAgICBzY2FuZigiJXMiLCBueXVyeW9rdSk7CiAgICBrYWlidW4gPSBzZXRQYWxpbmRyb21lKG55dXJ5b2t1KTsKCiAgICBpZiAoa2FpYnVuID09IE5VTEwpIHsKICAgICAgICBwcmludGYoIiVzXG4gIC0+IChudWxsKVxuIiwgbnl1cnlva3UpOwogICAgfSBlbHNlIHsKICAgICAgICBwcmludGYoIiVzXG4gIC0+ICVzXG4iLCBueXVyeW9rdSwga2FpYnVuKTsKICAgICAgICBmcmVlKGthaWJ1bik7CiAgICB9CgogICAgcmV0dXJuIDA7Cn0K