#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 slen = myStrlen(s);
	printf("%d\n",slen);
	tmp = (char *)malloc(sizeof(char)*(slen*2));
		if(tmp==NULL){
			printf("ERR");
			return;
		}
		int idx = 0;
		for(int i = 0; i<slen; i++){
			tmp[i] = s[i];
			idx++;
		}
		for(int i = slen - 2; i>=0; i--){
			tmp[idx] = s[i];
			idx++;
	}

	
	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;
}
