题解 | #蛇形矩阵#

蛇形矩阵

https://www.nowcoder.com/practice/f228a074c5274619b26be544962375e1

#include <stdio.h>

int main() {
   int n;
   scanf("%d",&n);
   int arr[n][n];
   int i=0,j=0;
   int p=1;
   arr[i][j]=p++;
   int flag=1;
   //等于1向右上角移动,等于-1向左下角移动
   while(p<=n*n){
    if(i==0&&j<n-1&&flag==1){//上边界
        arr[i][++j]=p++;
        flag=-1;
    }   
    else if(j==0&&i<n-1&&flag==-1){//左边界
        arr[++i][j]=p++;
        flag=1;
    }
    else if(j==n-1&&flag==1){//右边界
        arr[++i][j]=p++;
        flag=-1;
    }
    else if(i==n-1&&flag==-1){//下边界
        arr[i][++j]=p++;
        flag=1;
    }
    else if(flag==1){
        arr[--i][++j]=p++;
    }
    else{
        arr[++i][--j]=p++;
    }

   }

    for(int i=0;i<n;i++){
        for(int j=0;j<n;j++){
            printf("%d ",arr[i][j]);
        }
        printf("\n");
    }


    return 0;
}

全部评论

相关推荐

如题,八股刚开始学,准备好好沉淀八股,但是害怕没实习经历,简历筛选过不去,现在找实习却感觉都是已读不回,接下来该怎么安排呢?求教
Java抽象带篮子:具体背什么八股我都帮你整理好了,可以去看看我的八股专栏,这个比较详细,如果你觉得内容有点多记忆负担比较大的话,我还在更新最常问八股整理贴,是不是很贴心?
点赞 评论 收藏
分享
11-15 19:28
已编辑
蚌埠坦克学院 硬件开发
点赞 评论 收藏
分享
评论
1
1
分享
牛客网
牛客企业服务