#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 len = myStrlen(s);
int i;
// 回文の長さは元の文字列の2倍+終端文字分
tmp
= (char *)malloc(sizeof(char) * (len
* 2 + 1));
// 元の文字列をコピー
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; //回文を受け取る
kaibun = setPalindrome(nyuryoku);
printf("%s\n -> %s\n",nyuryoku
,kaibun
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICBpbnQgaTsKICAgIGZvcihpPTA7c1tpXSE9J1wwJztpKyspOwogICAgcmV0dXJuIGk7Cn0KCi8vIOmWouaVsOOBruS4reOBp3RtcOOBq+WvvuOBl+OBpm1hbGxvY+OBl+OBpgovLyDjgZ3jgZPjgavlm57mlofjgpLku6PlhaXjgZfjgaZyZXR1cm7jgafov5TjgZfjgb7jgZfjgofjgYYKY2hhciAqc2V0UGFsaW5kcm9tZShjaGFyIHNbXSl7CiAgICBjaGFyICp0bXA7CiAgICBpbnQgbGVuID0gbXlTdHJsZW4ocyk7CiAgICBpbnQgaTsKICAgIAogICAgLy8g5Zue5paH44Gu6ZW344GV44Gv5YWD44Gu5paH5a2X5YiX44GuMuWAjSvntYLnq6/mloflrZfliIYKICAgIHRtcCA9IChjaGFyICopbWFsbG9jKHNpemVvZihjaGFyKSAqIChsZW4gKiAyICsgMSkpOwogICAgCiAgICAvLyDlhYPjga7mloflrZfliJfjgpLjgrPjg5Tjg7wKICAgIGZvcihpID0gMDsgaSA8IGxlbjsgaSsrKXsKICAgICAgICB0bXBbaV0gPSBzW2ldOwogICAgfQogICAgCiAgICAvLyDpgIbpoIbjga7mloflrZfliJfjgpLpgKPntZAKICAgIGZvcihpID0gMDsgaSA8IGxlbjsgaSsrKXsKICAgICAgICB0bXBbbGVuICsgaV0gPSBzW2xlbiAtIDEgLSBpXTsKICAgIH0KICAgIAogICAgLy8g57WC56uv5paH5a2X44KS6L+95YqgCiAgICB0bXBbbGVuICogMl0gPSAnXDAnOwogICAgCiAgICByZXR1cm4gdG1wOwp9CgoKLy/jg6HjgqTjg7PplqLmlbDjga/jgYTjgZjjgovlv4XopoHjga/jgYLjgorjgb7jgZvjgpMKaW50IG1haW4oKXsKICAgLy8gaW50IGk7CiAgICBjaGFyIG55dXJ5b2t1WzEwMjRdOyAvL+WFpeWKmwogICAgY2hhciAqa2FpYnVuOyAgIC8v5Zue5paH44KS5Y+X44GR5Y+W44KLCiAgICBzY2FuZigiJXMiLG55dXJ5b2t1KTsKICAgIGthaWJ1biA9IHNldFBhbGluZHJvbWUobnl1cnlva3UpOwogICAgcHJpbnRmKCIlc1xuICAtPiAlc1xuIixueXVyeW9rdSxrYWlidW4pOwogICAgZnJlZShrYWlidW4pOwogICAgcmV0dXJuIDA7Cn0=