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