#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;
// 必要な長さ分を確保(s + reverse(s) + 終端)
tmp
= (char*)malloc((2 * len
+ 1) * sizeof(char));
// 前半:そのままコピー
for(i = 0; i < len; i++){
tmp[i] = s[i];
}
// 後半:逆順コピー
for(i = 0; i < len; i++){
tmp[len + i] = s[len - 1 - i];
}
// 終端文字
tmp[2 * len] = '\0';
return tmp;
}
//メイン関数はいじる必要はありません
int main(){
char nyuryoku[1024]; //入力
char *kaibun; //回文を受け取る
kaibun = setPalindrome(nyuryoku);
printf("%s\n -> %s\n",nyuryoku
,kaibun
); return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+CiNpbmNsdWRlIDxzdGRsaWIuaD4KCmludCBteVN0cmxlbihjaGFyIHNbXSl7CiAgICBpbnQgaTsKICAgIGZvcihpPTA7c1tpXSE9J1wwJztpKyspOwogICAgcmV0dXJuIGk7Cn0KCi8vIOmWouaVsOOBruS4reOBp3RtcOOBq+WvvuOBl+OBpm1hbGxvY+OBl+OBpgovLyDjgZ3jgZPjgavlm57mlofjgpLku6PlhaXjgZfjgaZyZXR1cm7jgafov5TjgZfjgb7jgZfjgofjgYYKY2hhciAqc2V0UGFsaW5kcm9tZShjaGFyIHNbXSl7CiAgICBjaGFyICp0bXA7CiAgICBpbnQgbGVuID0gbXlTdHJsZW4ocyk7CiAgICBpbnQgaTsKCiAgICAvLyDlv4XopoHjgarplbfjgZXliIbjgpLnorrkv53vvIhzICsgcmV2ZXJzZShzKSArIOe1guerr++8iQogICAgdG1wID0gKGNoYXIqKW1hbGxvYygoMiAqIGxlbiArIDEpICogc2l6ZW9mKGNoYXIpKTsKCiAgICAvLyDliY3ljYrvvJrjgZ3jga7jgb7jgb7jgrPjg5Tjg7wKICAgIGZvcihpID0gMDsgaSA8IGxlbjsgaSsrKXsKICAgICAgICB0bXBbaV0gPSBzW2ldOwogICAgfQoKICAgIC8vIOW+jOWNiu+8mumAhumghuOCs+ODlOODvAogICAgZm9yKGkgPSAwOyBpIDwgbGVuOyBpKyspewogICAgICAgIHRtcFtsZW4gKyBpXSA9IHNbbGVuIC0gMSAtIGldOwogICAgfQoKICAgIC8vIOe1guerr+aWh+WtlwogICAgdG1wWzIgKiBsZW5dID0gJ1wwJzsKCiAgICByZXR1cm4gdG1wOwp9CgovL+ODoeOCpOODs+mWouaVsOOBr+OBhOOBmOOCi+W/heimgeOBr+OBguOCiuOBvuOBm+OCkwppbnQgbWFpbigpewogICAgY2hhciBueXVyeW9rdVsxMDI0XTsgLy/lhaXlipsKICAgIGNoYXIgKmthaWJ1bjsgICAvL+WbnuaWh+OCkuWPl+OBkeWPluOCiwogICAgc2NhbmYoIiVzIixueXVyeW9rdSk7CiAgICBrYWlidW4gPSBzZXRQYWxpbmRyb21lKG55dXJ5b2t1KTsKICAgIHByaW50ZigiJXNcbiAgLT4gJXNcbiIsbnl1cnlva3Usa2FpYnVuKTsKICAgIGZyZWUoa2FpYnVuKTsKICAgIHJldHVybiAwOwp9Cg==