前几天去面试,遇到一个打印图案的题,结果类似于这样:
000000000
011111110
012222210
012333210
012343210
012333210
012222210
011111110
000000000
第一圈是0,第二圈是1,依此类推。考虑情况比较多,记录一下。
其实变化的规律要分把个区域来看,用两条横竖中线,两条对角线,将图形分成八个区域,还需要分奇数偶数,我是写了奇数,而且分类比较多,如果大家有更好的方法,欢迎交流。
#include <stdio.h>
#include <string.h>
#define N 9
char a[N][N];
int main(int argc, char** argv)
{
memset(a, 0, sizeof(a));
int i,j,center;
center = N/2;
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{
if(i<center&j<center)
{
if(i<j)
a[i][j] = i + 48;
else
a[i][j] = j + 48;
}
else if(i<center & j>center)
{
int t = N-1-j;
if(i<t)
a[i][j] = i + 48;
else
a[i][j] = t + 48;
}
else if(i == center|| j==center)
{
if(i==center&&j==center)
a[i][j] = N/2+48;
else if(i==center&j<center)
a[i][j] = j + 48;
else if(i==center&j>center)
a[i][j] = N-1-j+48;
else if(j==center&i<center)
a[i][j] = i + 48;
else if(j==center&i>center)
a[i][j] = N-1-i+48;
else
printf("==,i:%d,j:%d\n",i,j);
}
else if(i>center&j>center)
{
if(i>j)
a[i][j] = N - 1 - i + 48;
else
a[i][j] = N - 1 - j + 48;
}
else if(i>center & j< center)
{
int t = N - 1 - i;
if(t>j)
a[i][j] = j + 48;
else
a[i][j] = t + 48;
}
else
a[i][j] = '#';
}
}
for(i=0;i<N;i++)
{
for(j=0;j<N;j++)
{
printf("%c",a[i][j]);
}
printf("\n");
}
printf("=================\n");
}