#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 n=myStrlen(s);
int j=0;
char* s_trans;
s_trans
=(char*)malloc(sizeof(char)*(n
+1)); for(int i=n-1;i>=0;i--){
s_trans[j]=s[i];
j++;
}
s_trans[j]='\0';
tmp
=(char*)malloc(sizeof(char)*(2*n
+1)); for(int i=0;s[i]!='\0';i++){
tmp[i]=s[i];
}
for(int i=0;s_trans[i]!='\0';i++){
tmp[n+i]=s_trans[i];
}
tmp[2*n]='\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+OBpgovLyDjgZ3jgZPjgavlm57mlofjgpLku6PlhaXjgZfjgaZyZXR1cm7jgafov5TjgZfjgb7jgZfjgofjgYYKY2hhciAqc2V0UGFsaW5kcm9tZShjaGFyIHNbXSl7CgljaGFyICp0bXA7CgoJLy/ku6XkuIvjgavlv4XopoHjgarlrqPoqIDjgpLlkKvjgoHjgabmm7jjgYTjgabjgY/jgaDjgZXjgYQKCWludCBuPW15U3RybGVuKHMpOwoJaW50IGo9MDsKCWNoYXIqIHNfdHJhbnM7CglzX3RyYW5zPShjaGFyKiltYWxsb2Moc2l6ZW9mKGNoYXIpKihuKzEpKTsKCWZvcihpbnQgaT1uLTE7aT49MDtpLS0pewoJCXNfdHJhbnNbal09c1tpXTsKCQlqKys7Cgl9CglzX3RyYW5zW2pdPSdcMCc7CgkKCXRtcD0oY2hhciopbWFsbG9jKHNpemVvZihjaGFyKSooMipuKzEpKTsKCWZvcihpbnQgaT0wO3NbaV0hPSdcMCc7aSsrKXsKCQl0bXBbaV09c1tpXTsKCX0KCWZvcihpbnQgaT0wO3NfdHJhbnNbaV0hPSdcMCc7aSsrKXsKCQl0bXBbbitpXT1zX3RyYW5zW2ldOwoJfQoJdG1wWzIqbl09J1wwJzsKCQoJcmV0dXJuIHRtcDsKfQoKCi8v44Oh44Kk44Oz6Zai5pWw44Gv44GE44GY44KL5b+F6KaB44Gv44GC44KK44G+44Gb44KTCmludCBtYWluKCl7CiAgICBpbnQgaTsKICAgIGNoYXIgbnl1cnlva3VbMTAyNF07IC8v5YWl5YqbCiAgICBjaGFyICprYWlidW47ICAgLy/lm57mlofjgpLlj5fjgZHlj5bjgosKICAgIHNjYW5mKCIlcyIsbnl1cnlva3UpOwogICAga2FpYnVuID0gc2V0UGFsaW5kcm9tZShueXVyeW9rdSk7CiAgICBwcmludGYoIiVzXG4gIC0+ICVzXG4iLG55dXJ5b2t1LGthaWJ1bik7CiAgICBmcmVlKGthaWJ1bik7CiAgICByZXR1cm4gMDsKfQo=