打印一个N*N的方阵,N为每边字符的个数( 3〈N〈20 ),要求最外层为"X",第二层为"Y",从第三层起每层依次打印数字0,1,2,3,...
例子:当N =5,打印出下面的图形:
X X X X X
X Y Y Y X
X Y 0 Y X
X Y Y Y X
X X X X X
分析:该矩阵是一个原点对称矩阵,只要求出左上角的四分之一矩阵然后通过映射就可以。
具体代码如下:
#include<iostream>
using namespace std;
void PrintArray(int n,char (*a)[100])
{
int i,j,k,m,x,y;
for(i=0;i<=(n-1)/2;i++)
{
for(j=0;j<=(n-1)/2;j++)
{
int x,y;
x=i-2;y=j-2;
if(x==-2||y==-2)
{
a[i][j]='x';
}
else if(x==-1||y==-1)
{
a[i][j]='y';
}
else
{
if(i<j)
{
a[i][j]='0'+x;
}
else
{
a[i][j]='0'+y;
}
}
}
}
for(i=0;i<=(n-1)/2;i++)
{
for(j=(n+1)/2;j<n;j++)
{
a[i][j]=a[i][n-1-j];
}
}
for(i=(n+1)/2;i<n;i++)
{
for(j=0;j<=(n-1)/2;j++)
{
a[i][j]=a[n-1-i][j];
}
}
for(i=(n+1)/2;i<n;i++)
{
for(j=(n+1)/2;j<n;j++)
{
a[i][j]=a[i][n-1-j];
}
}
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
{
cout<<a[i][j]<<' ';
}
cout<<endl;
}
}
int main()
{
int n,i,j;
char a[100][100];
while(cin>>n)
{
PrintArray(n,a);
}
}