题解 | #回型矩阵#

回型矩阵

https://www.nowcoder.com/practice/36d5dfddc22c4f5b88a5b2a9de7db343

#include <stdio.h>
//通过控制边界来达到题目目的
int main() {
    int m[20][20]={0};
    int n;
    scanf("%d",&n);
    int i=1;
    int up=0;
    int left=0;
    int right=n-1;
    int down=n-1;
    while(i<=n*n)
    {
        for(int j=left;j<=right;j++)
        {
            m[up][j]=i++;
        }
        up++;

        for(int j=up;j<=down;j++)
        {
            m[j][right]=i++;
        }
        right--;
        for(int j=right;j>=left;j--)
        {
            m[down][j]=i++;
        }
        down--;
        for(int j=down;j>=up;j--)
        {
            m[j][left]=i++;
        }
        left++;

    }

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

    return 0;
}

全部评论

相关推荐

投了100多家都是石沉大海
迷茫的大四🐶:别急,现在都是92的✌🏻和大牛在乱杀,等秋招后期才轮到我们这些普通人
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务