#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[]){
int len = myStrlen(s);
// 回文は「元の文字列 + 逆順文字列」で作る
char *tmp
= malloc((2 * len
+ 1) * sizeof(char));
// 前半:元の文字列をコピー
for(int i = 0; i < len; i++){
tmp[i] = s[i];
}
// 後半:逆順にコピー
for(int i = 0; i < len; i++){
tmp[len + i] = s[len - 1 - i];
}
tmp[2 * len] = '\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+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICBpbnQgaTsKICAgIGZvcihpPTA7IHNbaV0gIT0gJ1wwJzsgaSsrKTsKICAgIHJldHVybiBpOwp9CgovLyDplqLmlbDjga7kuK3jgad0bXDjgavlr77jgZfjgaZtYWxsb2PjgZfjgaYKLy8g44Gd44GT44Gr5Zue5paH44KS5Luj5YWl44GX44GmcmV0dXJu44Gn6L+U44GX44G+44GX44KH44GGCmNoYXIgKnNldFBhbGluZHJvbWUoY2hhciBzW10pewogICAgaW50IGxlbiA9IG15U3RybGVuKHMpOwoKICAgIC8vIOWbnuaWh+OBr+OAjOWFg+OBruaWh+Wtl+WIlyArIOmAhumghuaWh+Wtl+WIl+OAjeOBp+S9nOOCiwogICAgY2hhciAqdG1wID0gbWFsbG9jKCgyICogbGVuICsgMSkgKiBzaXplb2YoY2hhcikpOwoKICAgIC8vIOWJjeWNiu+8muWFg+OBruaWh+Wtl+WIl+OCkuOCs+ODlOODvAogICAgZm9yKGludCBpID0gMDsgaSA8IGxlbjsgaSsrKXsKICAgICAgICB0bXBbaV0gPSBzW2ldOwogICAgfQoKICAgIC8vIOW+jOWNiu+8mumAhumghuOBq+OCs+ODlOODvAogICAgZm9yKGludCBpID0gMDsgaSA8IGxlbjsgaSsrKXsKICAgICAgICB0bXBbbGVuICsgaV0gPSBzW2xlbiAtIDEgLSBpXTsKICAgIH0KCiAgICB0bXBbMiAqIGxlbl0gPSAnXDAnOyAgLy8g57WC56uvCgogICAgcmV0dXJuIHRtcDsKfQoKLy/jg6HjgqTjg7PplqLmlbDjga/jgYTjgZjjgovlv4XopoHjga/jgYLjgorjgb7jgZvjgpMKaW50IG1haW4oKXsKICAgIGludCBpOwogICAgY2hhciBueXVyeW9rdVsxMDI0XTsgLy/lhaXlipsKICAgIGNoYXIgKmthaWJ1bjsgICAvL+WbnuaWh+OCkuWPl+OBkeWPluOCiwogICAgc2NhbmYoIiVzIixueXVyeW9rdSk7CiAgICBrYWlidW4gPSBzZXRQYWxpbmRyb21lKG55dXJ5b2t1KTsKICAgIHByaW50ZigiJXNcbiAgLT4gJXNcbiIsbnl1cnlva3Usa2FpYnVuKTsKICAgIGZyZWUoa2FpYnVuKTsKICAgIHJldHVybiAwOwp9Cg==