#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 counter = myStrlen(s);
int a = 0;
tmp
= (char *)malloc(sizeof(char)*counter
*2);
for(int i = 0; i < counter; i++)
{
tmp[i] = s[i];
}
for(int i = counter - 1; i >= 0; i--)
{
tmp[counter + a] += s[i];
a++;
}
return tmp;
}
//メイン関数はいじる必要はありません
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+OBoOOBleOBhAoJaW50IGNvdW50ZXIgPSBteVN0cmxlbihzKTsKCWludCBhID0gMDsKCQoJdG1wID0gKGNoYXIgKiltYWxsb2Moc2l6ZW9mKGNoYXIpKmNvdW50ZXIqMik7CgkKCWZvcihpbnQgaSA9IDA7IGkgPCBjb3VudGVyOyBpKyspCgl7CgkJdG1wW2ldID0gc1tpXTsKCX0KCQoJZm9yKGludCBpID0gY291bnRlciAtIDE7IGkgPj0gMDsgaS0tKQoJewoJCXRtcFtjb3VudGVyICsgYV0gKz0gc1tpXTsKCQlhKys7Cgl9CgkKCXJldHVybiB0bXA7Cn0KCgovL+ODoeOCpOODs+mWouaVsOOBr+OBhOOBmOOCi+W/heimgeOBr+OBguOCiuOBvuOBm+OCkwppbnQgbWFpbigpewogICAgaW50IGk7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAvL+WFpeWKmwogICAgY2hhciAqa2FpYnVuOyAgIC8v5Zue5paH44KS5Y+X44GR5Y+W44KLCiAgICBzY2FuZigiJXMiLG55dXJ5b2t1KTsKICAgIGthaWJ1biA9IHNldFBhbGluZHJvbWUobnl1cnlva3UpOwogICAgcHJpbnRmKCIlc1xuICAtPiAlc1xuIixueXVyeW9rdSxrYWlidW4pOwogICAgZnJlZShrYWlidW4pOwogICAgcmV0dXJuIDA7Cn0KCi8qCuaWuemHnQrinpTmloflrZfmlbDjgpLmlbDjgYjjgIHljYrliIbjga7kvY3nva7jgYvjgonlm57mlofjgavjgarjgorjgYvjgZHjgabjgYTjgovjgYvjg4Hjgqfjg4Pjgq/inpTotrPjgorjgabjgYTjgarjgYTpg6jliIbjgpLotrPjgZkKKi8=