输入一个长度不超过50的由小字字母构成的字符串,输出由这个字符序列构成的最大的正方形。
输入格式:
由小写字母构成的一个字符串。
输出格式:
将字符串围成最大可能的正方形输出,字符串从正方形的左上方开始,按顺时针方向绕行。
输入样例1:
a
输出样例1:
a
输入样例2:
happy
输出样例2:
ha
pp
输入样例3:
abcdefghijklmn
输出样例3:
abcd
l e
k f
jihg
#include<bits/stdc++.h>
using namespace std;
int main(){
string s;
int i,j,k;
cin>>s;
int flag,flag1;
k=1+s.size()/4; //第一行,最后一行的字符个数
for(i=0;i<k;i++){
cout<<s[i]; //输出第一行
if(i==k-1){
flag=i+1;
cout<<endl;
}
}
flag1=k+k+(k-2)*2-1;
for(j=0;j<k-2;j++){
cout<<s[flag1];
flag1--;
for(l=0;l<k-2;l++){ //输出中间行,中间用空格填充
cout<<' ';
}
cout<<s[flag]<<endl;
flag++;
}
for(j=0;j<k;j++){
cout<<s[flag1]; //输出最后一行
if(j==k-1){
cout<<endl;
}
flag1--;
}
return 0;
}