题解 | #蛇形矩阵#

蛇形矩阵

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;
}

全部评论

相关推荐

评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务