#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 i,size;
	size=myStrlen(s);
	tmp=(char*)malloc(sizeof(char*)*(size*2+1)); //(size*2+1)は元の文×２+文字列の終わりの \0
	if(tmp==NULL){
		printf("ERROR\n");
		return 0;
	}
	for(i=0;i<size;i++){
		tmp[i]=s[i];
		tmp[i+size]=s[size-i-1];
		//i=0,size=3の時、tmp[0+3] = s[3-0-1] → tmp[3] = s[2]
	}
	tmp[size*2]='\0';//ヌル文字代入
	return tmp;

}


//メイン関数はいじる必要はありません
int main(){
    int i;
    char nyuryoku[1024]; //入力
    char *kaibun;   //回文を受け取る
    scanf("%s",nyuryoku);
    kaibun = setPalindrome(nyuryoku);
    printf("%s\n  -> %s\n",nyuryoku,kaibun);
    free(kaibun);
    return 0;
}
