#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;
//以下に必要な宣言を含めて書いてください
int i,j,k;
int size = myStrlen(s);
tmp
= (char*)malloc(sizeof(char)*(size
* 2));
for(i=0;i<size;i++){ // tmpにsの文を入れる
tmp[i] = s[i];
}
for(j=0;j<size-1;j++){
for(k=0;k<size-1+j;k++){
if(tmp[k] != tmp[size-1 + j-k]) //回文の判定
break;
}
if(k>=size-1+j){ //回文であれば終了、回文でなければ続行
tmp[size+j] = '\0';
return tmp;
}
tmp[size+j] = s[size-j-2]; //sの後ろから2番目の値から代入
}
}
//メイン関数はいじる必要はありません
int main(){
int i;
char nyuryoku[1024]; //入力
char *kaibun; //回文を受け取る
kaibun = setPalindrome(nyuryoku);
printf("%s\n -> %s\n",nyuryoku
,kaibun
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICBpbnQgaTsKICAgIGZvcihpPTA7c1tpXSE9J1wwJztpKyspOwogICAgcmV0dXJuIGk7Cn0KCi8vIOmWouaVsOOBruS4reOBp3RtcOOBq+WvvuOBl+OBpm1hbGxvY+OBl+OBpgovLyDjgZ3jgZPjgavlm57mlofjgpLku6PlhaXjgZfjgaZyZXR1cm7jgafov5TjgZfjgb7jgZfjgofjgYYKY2hhciAqc2V0UGFsaW5kcm9tZShjaGFyIHNbXSl7CgljaGFyICp0bXA7CgkvL+S7peS4i+OBq+W/heimgeOBquWuo+iogOOCkuWQq+OCgeOBpuabuOOBhOOBpuOBj+OBoOOBleOBhAoJaW50IGksaixrOwoJaW50IHNpemUgPSBteVN0cmxlbihzKTsKCQoJdG1wID0gKGNoYXIqKW1hbGxvYyhzaXplb2YoY2hhcikqKHNpemUgKiAyKSk7CgkKCWZvcihpPTA7aTxzaXplO2krKyl7IC8vCXRtcOOBq3Pjga7mlofjgpLlhaXjgozjgosKCQl0bXBbaV0gPSBzW2ldOwoJfQoJCglmb3Ioaj0wO2o8c2l6ZS0xO2orKyl7CgkJZm9yKGs9MDtrPHNpemUtMStqO2srKyl7CgkJCWlmKHRtcFtrXSAhPSB0bXBbc2l6ZS0xICsgai1rXSkgLy/lm57mlofjga7liKTlrpoKCQkJCWJyZWFrOwoJCX0KCQlpZihrPj1zaXplLTErail7IC8v5Zue5paH44Gn44GC44KM44Gw57WC5LqG44CB5Zue5paH44Gn44Gq44GR44KM44Gw57aa6KGMCgkJCXRtcFtzaXplK2pdID0gJ1wwJzsKCQkJcmV0dXJuIHRtcDsKCQl9CgkJdG1wW3NpemUral0gPSBzW3NpemUtai0yXTsgLy9z44Gu5b6M44KN44GL44KJ77yS55Wq55uu44Gu5YCk44GL44KJ5Luj5YWlCgl9Cn0KCgovL+ODoeOCpOODs+mWouaVsOOBr+OBhOOBmOOCi+W/heimgeOBr+OBguOCiuOBvuOBm+OCkwppbnQgbWFpbigpewogICAgaW50IGk7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAvL+WFpeWKmwogICAgY2hhciAqa2FpYnVuOyAgIC8v5Zue5paH44KS5Y+X44GR5Y+W44KLCiAgICBzY2FuZigiJXMiLG55dXJ5b2t1KTsKICAgIGthaWJ1biA9IHNldFBhbGluZHJvbWUobnl1cnlva3UpOwogICAgcHJpbnRmKCIlc1xuICAtPiAlc1xuIixueXVyeW9rdSxrYWlidW4pOwogICAgZnJlZShrYWlidW4pOwogICAgcmV0dXJuIDA7Cn0K