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

    tmp = (char*)malloc(2 * len + 1);
    if (tmp == NULL) { 
        printf("メモリ確保に失敗しました\n");
        return NULL;
    }

    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(){
    int i;
    char nyuryoku[1024]; //入力
    char *kaibun;   //回文を受け取る
    scanf("%s",nyuryoku);
    kaibun = setPalindrome(nyuryoku);
    printf("%s\n  -> %s\n",nyuryoku,kaibun);
    free(kaibun);
    return 0;
}
