需求如下:
#include <stdio.h>
#include <stdlib.h>
#define N 100
int a[N][N] = {0};
int n = 0;
typedef enum _MOVEDIR
{
move_rt = 1, //右上移动
move_lb = 2, //左下移动
}MOVEDIR;
void snake()
{
int i=0,j=0;
MOVEDIR md = move_rt;
bool bhwMove = false; //是否水平或垂直移动
for(int k=1;k<=N*N;k++)
{
if(a[i][j] == 0)
a[i][j] = k;
else
k--;
if(k==15)
int kk = 0;
//
switch(md)
{
case move_rt: //右上移动,i--,j++
{
if(i==0) //如果移出上边界
{
if(bhwMove) //如果之前已经横向移动,则转为向左下移动
{
bhwMove = false;
md = move_lb;
i++;
j--;
}
else //否则,进行先横向移动一次
{
bhwMove = true;
if(j==n-1)
i++;
else
j++;
}
}
else if(j==n-1) //移出右边界
{
if(bhwMove)
{
bhwMove = false;
md = move_lb;
i++;
j--;
}
else
{
bhwMove = true;
i++;
}
}
else
{
i--;
j++;
}
}
break;
case move_lb://左下移动,i++,j--
{
if(j==0) //如果移出上边界
{
if(bhwMove) //如果之前已经向下移动,则转为向右上移动
{
bhwMove = false;
md = move_rt;
i--;
j++;
}
else //否则,进行先向下移动一次
{
bhwMove = true;
if(i == n-1)
j++;
else
i++;
}
}
else if(i==n-1) //移出底边界
{
if(bhwMove)
{
bhwMove = false;
md = move_rt;
i--;
j++;
}
else
{
bhwMove = true;
j++;
}
}
else
{
i++;
j--;
}
}
break;
}
}
}
int main()
{
while(1)
{
system("cls");
printf("请输入矩阵大小(<=1则结束:");
scanf("%d",&n);
if(n<=1)
return 0;
int i,j;
for(i=0;i<n;i++)
for(j=0;j<n;j++)
a[i][j] = 0;
snake();
for(i=0;i<n;i++)
{
for(j=0;j<n;j++)
printf("%4d",a[i][j]);
printf("\n");
}
system("pause");
}
return 0;
}