7-1 美丽的字符正方形FINAL (10分)
输入一个长度不超过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()
{
int n,x,i,j;
string s;
cin>>s;
n=s.length();
if(n<4){
cout<<s[0]<<endl;
}
else
{
x=(n+4)/4;
for(i=0; i<x; i++)
{
cout<<s[i];
}
cout<<endl;
int a=4*x-5;
int b=x;
for(i=0; i<x-2; i++)
{
cout<<s[a--]<< setw(x-1)<<s[b++]<<endl;
}
for(;a>=b;a--){
cout<<s[a];
}
cout<<endl;
}
return 0;
}
大概,
1 2 3 ..... n
4n-4 (n-2个空格) n+1
4n-5 (n-2个空格) n+2
...... ......
3n-3 (n-2个 数 ) 2n-2