#include <stdio.h>
#include <stdlib.h>
int myStrlen(char s[]){
int i;
for(i=0;s[i]!='\0';i++);
return i;
}
// 関数の中でtmpに対してmallocして
// そこに回文を代入してreturnで返しましょう
char *setPalindrome(char s[]){
char *tmp,*a;
int i,k,j,n,b;
k=myStrlen(s);
tmp
=(char*)malloc(sizeof(char)*k
*2); a
=(char*)malloc(sizeof(char)*k
); for(i=0;i<k;i++){
tmp[i]=s[i];
a[i]=s[i];
}
for(i=1;i<=k;i++){
n=k-i;
for(j=0;j<i;j++){
if(tmp[n]==a[k-j-1]){
if(j==i-1) b=i;
}else{
break;
}
n++;
}
}
for(i=0;i<k-b;i++){
tmp[i+k]=a[k-i-b-1];
}
return tmp;
}
//メイン関数はいじる必要はありません
int main(){
int i;
char nyuryoku[1024]; //入力
char *kaibun; //回文を受け取る
kaibun = setPalindrome(nyuryoku);
printf("%s\n -> %s\n",nyuryoku
,kaibun
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KIAppbnQgbXlTdHJsZW4oY2hhciBzW10pewogICAgaW50IGk7CiAgICBmb3IoaT0wO3NbaV0hPSdcMCc7aSsrKTsKICAgIHJldHVybiBpOwp9CiAKLy8g6Zai5pWw44Gu5Lit44GndG1w44Gr5a++44GX44GmbWFsbG9j44GX44GmCi8vIOOBneOBk+OBq+WbnuaWh+OCkuS7o+WFpeOBl+OBpnJldHVybuOBp+i/lOOBl+OBvuOBl+OCh+OBhgpjaGFyICpzZXRQYWxpbmRyb21lKGNoYXIgc1tdKXsKCWNoYXIgKnRtcCwqYTsKCWludCBpLGssaixuLGI7CglrPW15U3RybGVuKHMpOwoJdG1wPShjaGFyKiltYWxsb2Moc2l6ZW9mKGNoYXIpKmsqMik7CglhPShjaGFyKiltYWxsb2Moc2l6ZW9mKGNoYXIpKmspOwoJZm9yKGk9MDtpPGs7aSsrKXsKCQl0bXBbaV09c1tpXTsKCQlhW2ldPXNbaV07Cgl9Cglmb3IoaT0xO2k8PWs7aSsrKXsKCQluPWstaTsKCQlmb3Ioaj0wO2o8aTtqKyspewoJCQlpZih0bXBbbl09PWFbay1qLTFdKXsKCQkJCWlmKGo9PWktMSkgYj1pOwoJCQl9ZWxzZXsKCQkJCWJyZWFrOwoJCQl9CgkJCW4rKzsKCQl9Cgl9Cglmb3IoaT0wO2k8ay1iO2krKyl7CgkJdG1wW2kra109YVtrLWktYi0xXTsKCX0KCXJldHVybiB0bXA7Cn0KIAogCi8v44Oh44Kk44Oz6Zai5pWw44Gv44GE44GY44KL5b+F6KaB44Gv44GC44KK44G+44Gb44KTCmludCBtYWluKCl7CiAgICBpbnQgaTsKICAgIGNoYXIgbnl1cnlva3VbMTAyNF07IC8v5YWl5YqbCiAgICBjaGFyICprYWlidW47ICAgLy/lm57mlofjgpLlj5fjgZHlj5bjgosKICAgIHNjYW5mKCIlcyIsbnl1cnlva3UpOwogICAga2FpYnVuID0gc2V0UGFsaW5kcm9tZShueXVyeW9rdSk7CiAgICBwcmludGYoIiVzXG4gIC0+ICVzXG4iLG55dXJ5b2t1LGthaWJ1bik7CiAgICBmcmVlKGthaWJ1bik7CiAgICByZXR1cm4gMDsKfQ==