输入一个长度不超过50的由小字字母构成的字符串,输出由这个字符序列构成的最大的正方形。
输入格式:
由小写字母构成的一个字符串。
输出格式:
将字符串围成最大可能的正方形输出,字符串从正方形的左上方开始,按顺时针方向绕行。
输入样例1:
a
输出样例1:
a
输入样例2:
happy
输出样例2:
ha
pp
输入样例3:
abcdefghijklmn
输出样例3:
abcd
l e
k f
jihg
ac:
#include<iostream>
#include<string>
using namespace std;
char num[45][45];
void intial()
{
for(int i=0;i<45;++i)
{
for(int j=0;j<45;++j)
{
num[i][j]=' ';
}
}
}
int main()
{
intial();
string a="";
getline(cin,a);
int x=0;
x=a.length()/4+1;
int t=0;
for(int j=0;j<x;++j)
{
num[0][j]=a[t++];
}
for(int j=1;j<x;++j)
{
num[j][x-1]=a[t++];
}
for(int j=x-2;j>0;--j)
{
num[x-1][j]=a[t++];
}
for(int j=x-1;j>0;--j)
{
num[j][0]=a[t++];
}
int i,j;
for( i=0;i<x-1;++i)
{
for(j=0;j<x;++j)
{
cout<<num[i][j];
}
cout<<endl;
}
for(int j=0;j<x;++j)
{
cout<<num[i][j];
}
return 0;
}
wa:” '\0' “和” ‘ ' “ 虽然 输出的图形是一样的但是还是会被检测出来,所以要进行初始化
#include<iostream>
#include<string>
using namespace std;
int main()
{
string a="";
getline(cin,a);
int x=0;
x=a.length()/4+1;
char num[x][x]={'\0'};
int t=0;
for(int j=0;j<x;++j)
{
num[0][j]=a[t++];
}
for(int j=1;j<x;++j)
{
num[j][x-1]=a[t++];
}
for(int j=x-2;j>0;--j)
{
num[x-1][j]=a[t++];
}
for(int j=x-1;j>0;--j)
{
num[j][0]=a[t++];
}
for(int i=0;i<x;++i)
{
for(int j=0;j<x;++j)
{
cout<<num[i][j];
}
cout<<endl;
}
return 0;
}