题解 | #蛇形矩阵#

蛇形矩阵

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

全部评论

相关推荐

10-13 17:47
门头沟学院 Java
wulala.god:图一那个善我面过,老板网上找的题库面的
点赞 评论 收藏
分享
offerboyyyy:之前看到降温完收到offer了的呢佬,可以签保底等
点赞 评论 收藏
分享
11-28 17:48
中山大学 C++
点赞 评论 收藏
分享
评论
1
1
分享
牛客网
牛客企业服务