算法刷题笔记【数组】59.螺旋矩阵II

算法刷题笔记【数组】59.螺旋矩阵II

给定一个正整数 n,生成一个包含 1 到 n^2 所有元素,且元素按顺时针顺序螺旋排列的正方形矩阵。

示例:

输入: 3 输出: [ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7, 6, 5 ] ]

模拟法

思路:要坚持循环不变量原则,模拟顺时针画矩阵的过程:

  • 填充上行从左到右
  • 填充右列从上到下
  • 填充下行从右到左
  • 填充左列从下到上

由外向内一圈一圈这么画下去,每画一条边都要坚持一致的左闭右开的原则

class lc059_generateMatrix{
public:
    vector<vector<int>> generateMatrix(int n) {

        // 0.初始化一个n行n列的二维数组(一维:vector<int> vec(n);)
        vector<vector<int>> ans(n, vector<int>(n, 0));

        int round = n / 2;
        int count = 1;
        int startX = 0, startY = 0;
        int i, j;
        int offset = 1;
        int mid = n / 2;

        while(round--) {

            i = startX;
            j = startY;

            for (j = startY; j < n - offset; ++j) {
                ans[startX][j] = count++;
            }

            for (i = startX; i < n - offset; ++i) {
                ans[i][j] = count++;
            }

            for (; j > startY; --j) {
                ans[i][j] = count++;
            }

            for (; i > startX; --i) {
                ans[i][j] = count++;
            }

            startX++, startY++;
            offset += 1;
        }

        if (n % 2 == 1) {
//            ans[i][j] = count;
//            ans[++i][++j] = count;
            ans[mid][mid] = count;
        }

        return ans;

    }
}

小结

    细节太多,想起信心满满,却不断出错,有点羞愤,又有点恼,简直打脸!

    做题过程中,刚开始是`while`循环中的循环次数忘记自减导致程序死循环,尴尬!

    关于**最后一个元素**的处理,一开始想着`i`和`j`最终会移动到中间位置,就直接使用`ans[i][j] = count;`加上测试时用`3`作为数组阶数,一运行,发现最后一个数是`0`,而且`i`和`j`都为`0`,给我整不会了,甚至怀疑作用域有问题。后来才发现,`i`和`j`在最后一个元素的前一个位置,一般情况下是在其左边。好,那在赋值的时候先自增一下不就好了?`ans[++i][++j] = count;`,给个`5`跑一下,正确!美滋滋 ~ 提交!执行错误!懵了,一看发现是输入为`1`的时候结果错了。凸(艹皿艹 ),原来,为`1`的时候,`ans[++i][++j] = count;`不就越界了嘛!好了,还是老老实实用一个单独的变量来表示最中间的那个值好了。`int mid = n / 2; ans[mid][mid] = count;`

附录

给出完整的可运行的程序清单.h.cpp文件

/**********************************************************
> FilePath:     lc059_generateMatrix.h
> Author:       @leon-ais
> Mail:         leon-ais@qq.com
> Date:         9/26/2022 9:19 AM
> Description:  59.螺旋矩阵II
***********************************************************/
#ifndef C_TUTORIAL_LC059_GENERATEMATRIX_H
#define C_TUTORIAL_LC059_GENERATEMATRIX_H

#include <iostream>
#include <vector>
#include <string>

using namespace std;

class lc059_generateMatrix{
public:
    vector<vector<int>> generateMatrix(int n) {

        // 0.初始化一个n行n列的二维数组(一维:vector<int> vec(n);)
        vector<vector<int>> ans(n, vector<int>(n, 0));

        int round = n / 2;
        int count = 1;
        int startX = 0, startY = 0;
        int i, j;
        int offset = 1;
        int mid = n / 2;

        while(round--) {

            i = startX;
            j = startY;

            for (j = startY; j < n - offset; ++j) {
                ans[startX][j] = count++;
            }

            for (i = startX; i < n - offset; ++i) {
                ans[i][j] = count++;
            }

            for (; j > startY; --j) {
                ans[i][j] = count++;
            }

            for (; i > startX; --i) {
                ans[i][j] = count++;
            }

            startX++, startY++;
            offset += 1;
        }

        if (n % 2 == 1) {
//            ans[i][j] = count;
//            ans[++i][++j] = count;
            ans[mid][mid] = count;
        }

        return ans;

    }

    void print2Darr(vector<vector<int>> a) {
        int m = a.size(), n = a[0].size();
        // 2.美化打印一个二维数组
        cout << "ans=[";
        for (int i = 0; i < m; ++i) {
            cout << endl;
            cout << ((i == 0) ? "[" : ", [");
            for (int j = 0; j < n; ++j) {
                cout << ((j == 0) ? "" : ", ") << a[i][j];
            }
            cout << "]";
        }
        cout << "]" << endl;
    }

    vector<vector<int>> matrixTest(int n) {

        // 0.使用vector初始化一个n * n数组
        vector<vector<int>> ans(n, vector<int>(n, 0));

        // 1.双层for循环给二维数组赋值
        int count = 0;
        for (int i = 0; i < n; ++i) {
            for (int j = 0; j < n; ++j) {
                ans[i][j] = count++;
            }
        }

        // 2.美化打印一个二维数组
        cout << "ans=[";
        for (int i = 0; i < n; ++i) {
            cout << endl;
            cout << ((i == 0) ? "[" : ", [");
            for (int j = 0; j < n; ++j) {
                cout << ((j == 0) ? "" : ", ") << ans[i][j];
            }
            cout << "]";
        }
        cout << "]" << endl;

        return ans;
    }

};

#endif //C_TUTORIAL_LC059_GENERATEMATRIX_H

/**********************************************************
> FilePath:     lc059_generateMatrix.cpp
> Author:       @leon-ais
> Mail:         leon-ais@qq.com
> Date:         9/26/2022 9:19 AM
> Description:  59.螺旋矩阵II
***********************************************************/
#include "lc059_generateMatrix.h"

void init_test() {
    lc059_generateMatrix matrix;
    matrix.matrixTest(9);
    int n = 9;
    vector<vector<int>> a(n);
    vector<vector<int>> c(n, vector<int>(n, 1));
    vector<vector<int>> b(n, vector<int>(n, 0));
    matrix.print2Darr(a);
}

int main() {

    lc059_generateMatrix matrix;
    vector<vector<int>> b = matrix.generateMatrix(1);
    matrix.print2Darr(b);

    return 0;
}

完事~

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,539评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,911评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,337评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,723评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,795评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,762评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,742评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,508评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,954评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,247评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,404评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,104评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,736评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,352评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,557评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,371评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,292评论 2 352

推荐阅读更多精彩内容