如下,蛇形矩阵个人感觉是个很精妙的设计,每次先确定当前坐标上的数字,再确定下一个坐标,以此往复,完成二维数组的赋值后一并输出即可
#include<stdio.h>
int a, b, res[101][101];//存储坐标用的数组
//以(0,0)为原点,右下为正方向
int dx[] = { 1,0,-1,0 }, dy[] = { 0,1,0,-1 };//每次可能向上下左右移动
signed main() {
printf("输入蛇形矩阵的长和宽:");
scanf("%d%d", &a, &b);
for (int i = 0, j = 0, x = 0, y = 0, t = 0, num = 1; num <= a * b; num++) {
//先遍历一遍
res[i][j] = num;
x = i + dx[t], y = j + dy[t];//下一次的坐标
if (x < 0 || x >= a || y < 0 || y >= b || res[x][y]) {//如果越界或者重复就换个方向
t = (t + 1) % 4;
x = i + dx[t], y = j + dy[t];//新的坐标
}
i = x, j = y;//将坐标赋值回去
}
printf("%d行%d列的蛇形矩阵为:\n", b, a);
for (int i = 0; i < b; i++) {//共b行
for (int j = 0; j < a; j++) {//共a列
printf("%d\t", res[j][i]);
}
printf("\n");
}
return 0;
}