首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

分享一路笔试题

2012-09-28 
分享一道笔试题打印一个N*N的方阵,N为每边字符的个数( 3〈N〈20 ),要求最外层为X,第二层为Y,从第三层起

分享一道笔试题

打印一个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);}}


 

热点排行