题解 | #蛇形矩阵#
蛇形矩阵
https://www.nowcoder.com/practice/649b210ef44446e3b1cd1be6fa4cab5e
#include <stdio.h> /* 思路:利用二维数组的index进行操作 arr[n][n],a[0][0]=1,a[0+1][0]=1+1;a[0][0+1]=a[0+1][0]+1; */ //#define n 6 int *CreateMatrix(int n) { int (*arr)[n]=(int (*)[n])malloc(n*n*sizeof(int)); int *p=arr; int curnum=1; int newraw=0; for(int i=0;i<n;i++) { arr[newraw++][0]=curnum++;//定位最新行首元素 //接下来就是行数-1,列数+1的+1赋值 for(int j=0;j<newraw&&i>0;) { arr[--i][++j]=curnum++; //for } i=newraw-1; } //p+n+ return p; } int main() { int n=1; scanf("%d",&n); int (*p)[n]=(int (*)[n])CreateMatrix(n);//将p初始化为以隔n个int为单位的指针,虽然用了一个不常见的强制转化,但看起来可行 for(int i=0;i<n;i++) { for(int j=0;j<n-i;j++) { printf("%d ",p[i][j]); } printf("\n"); } return 0; }