题解 | #蛇形矩阵#

蛇形矩阵

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

全部评论

相关推荐

11-18 15:57
门头沟学院 Java
最终归宿是测开:这个重邮的大佬在重邮很有名的,他就喜欢打92的脸,越有人质疑他,他越觉得爽😂
点赞 评论 收藏
分享
努力学习的小绵羊:我反倒觉得这种挺好的,给不到我想要的就别浪费大家时间了
点赞 评论 收藏
分享
评论
1
1
分享
牛客网
牛客企业服务