#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) * (len
* 2 + 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[len * 2] = '\0';
return tmp;
}
int main(){
int i;
char nyuryoku[1024];
char *kaibun;
if (scanf("%s", nyuryoku
) != 1) return 1;
kaibun = setPalindrome(nyuryoku);
if (kaibun != NULL) {
printf("%s -> %s\n", nyuryoku
, kaibun
); }
return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICBpbnQgaTsKICAgIGZvcihpPTA7c1tpXSE9J1wwJztpKyspOwogICAgcmV0dXJuIGk7Cn0KCgpjaGFyICpzZXRQYWxpbmRyb21lKGNoYXIgc1tdKXsKICAgIGludCBsZW4gPSBteVN0cmxlbihzKTsKICAgIGludCBpOwogIAogICAgY2hhciAqdG1wID0gKGNoYXIgKiltYWxsb2Moc2l6ZW9mKGNoYXIpICogKGxlbiAqIDIgKyAxKSk7CiAgICAKICAgIGlmICh0bXAgPT0gTlVMTCkgcmV0dXJuIE5VTEw7IAoKICAgCiAgICBmb3IoaSA9IDA7IGkgPCBsZW47IGkrKykgewogICAgICAgIHRtcFtpXSA9IHNbaV07CiAgICB9CgoKICAgIGZvcihpID0gMDsgaSA8IGxlbjsgaSsrKSB7CiAgICAgICAgdG1wW2xlbiArIGldID0gc1tsZW4gLSAxIC0gaV07CiAgICB9CgogICAgdG1wW2xlbiAqIDJdID0gJ1wwJzsKCiAgICByZXR1cm4gdG1wOwp9CgppbnQgbWFpbigpewogICAgaW50IGk7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAKICAgIGNoYXIgKmthaWJ1bjsgICAKICAgIAogICAgaWYgKHNjYW5mKCIlcyIsIG55dXJ5b2t1KSAhPSAxKSByZXR1cm4gMTsKICAgIAogICAga2FpYnVuID0gc2V0UGFsaW5kcm9tZShueXVyeW9rdSk7CiAgICAKICAgIGlmIChrYWlidW4gIT0gTlVMTCkgewogICAgICAgIHByaW50ZigiJXMgLT4gJXNcbiIsIG55dXJ5b2t1LCBrYWlidW4pOwogICAgICAgIGZyZWUoa2FpYnVuKTsgCiAgICB9CiAgICAKICAgIHJldHVybiAwOwp9