//
// main.cpp
// bzoj1692
//
// Created by Candy on 2016/12/29.
// Copyright © 2016年 Candy. All rights reserved.
//
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
const int N=6e4+5;
int n,n1,n2,m;
char s[3],a[N];
int sa[N],c[N],t1[N],t2[N];
inline bool cmp(int *r,int a,int b,int j){
return a+j<=n&&b+j<=n&&r[a]==r[b]&&r[a+j]==r[b+j];
}
int rnk[N],height[N];
void getHeight(char s[]){
int k=0;
for(int i=1;i<=n;i++) rnk[sa[i]]=i;
for(int i=1;i<=n;i++){
if(k) k--;
if(rnk[i]==1) continue;
int j=sa[rnk[i]-1];
while(i+k<=n&&j+k<=n&&s[i+k]==s[j+k]) k++;
height[rnk[i]]=k;
}
}
void getSA(char s[]){
int *r=t1,*k=t2;
for(int i=0;i<=m;i++) c[i]=0;
for(int i=1;i<=n;i++) c[r[i]=s[i]]++;
for(int i=1;i<=m;i++) c[i]+=c[i-1];
for(int i=n;i>=1;i--) sa[c[r[i]]--]=i;
for(int j=1;j<=n;j<<=1){
int p=0;
for(int i=n-j+1;i<=n;i++) k[++p]=i;
for(int i=1;i<=n;i++) if(sa[i]>j) k[++p]=sa[i]-j;
for(int i=0;i<=m;i++) c[i]=0;
for(int i=1;i<=n;i++) c[r[k[i]]]++;
for(int i=1;i<=m;i++) c[i]+=c[i-1];
for(int i=n;i>=1;i--) sa[c[r[k[i]]]--]=k[i];
swap(r,k);p=0;r[sa[1]]=++p;
for(int i=2;i<=n;i++) r[sa[i]]=cmp(k,sa[i],sa[i-1],j)?p:++p;
if(p>=n) break;m=p;
}
}
int cnt=0,head,tail;
void solve(){
head=1;tail=n1+2;
for(int d=1;d<=n1;d++){
if(rnk[head]<rnk[tail]) putchar(a[head++]);
else putchar(a[tail++]);
if(d%80==0) putchar(‘\n‘);
}
}
int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++) scanf("%s",s),a[i]=s[0];
a[n+1]=1;
for(int i=1;i<=n;i++) a[n+1+i]=a[n+1-i];
n1=n;
n=n+n+1;
m=300;
getSA(a);
getHeight(a);
solve();
}