题解 | #回型矩阵#

回型矩阵

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

#include <iostream>
using namespace std;
//利用边界条件之间的关系进行条件判断,赋值,分两步进行
//1.将方阵分为外层,内层
//2.对外层进行赋值,完成后,内层变为外层 ,重复
int main() {
    int n, up, down, right, left, count = 1;
    scanf("%d",&n);
    int map[n][n];
    up = 0, right = n - 1, left = 0, down = n - 1;
    while (up < down || left < right) {
        for (int i = left; i < right ; i++) {//上端赋值
            map[up][i] = count++;
        }
        for (int i = left; i < down ; i++) {//左侧赋值
            map[i][right] = count++;
        }
        for (int i = right ; i > left; i--) {//下端赋值
            map[down][i] = count++;
        }
        for (int i = down ; i > left; i--) {//右侧赋值
            map[i][left] = count++;
        }
        up++;			//将内层切换成外层
        down--;
        left++;
        right--;
    }
    if(left == right && up == down) map[up][down] = count;//对于奇数层数的矩阵,中间数需要另外赋值
    for (int i = 0; i < n; i++) {
        for (int j = 0; j < n; j++) {
            cout << map[i][j] << ' ';
        }
        cout << endl;
    }
    return 0;
}

全部评论

相关推荐

北斗导航Compass低仿版:学历一般 没实习 非科班,肯定很难过初筛了,先找个中小厂好好干吧,拿这段实习去投大厂实习
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务