LeetCode—59. Spiral Matrix II

Type:medium

Given a positive integer n, generate a square matrix filled with elements from 1 to n2in spiral order.

Example:

Input:3Output:[ [ 1, 2, 3 ], [ 8, 9, 4 ], [ 7, 6, 5 ]]


输入一个数字n,输出n*n的螺旋状数组。

和之前一样,按顺序输出即可。注意如何定义二维数组。


class Solution {

public:

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

        vector<vector<int>> ret(n, vector<int>(n, 0));

        int c = n/2;

        int m = 1;

        for(int i=0; i<c; i++){

            for(int j=i; j<=n-1-i; j++){

                ret[i][j] = m++;

            }

            for(int j=i+1; j<=n-1-i; j++){

                ret[j][n-1-i] = m++;

            }

            for(int j=n-2-i; j>=i; j--){

                ret[n-1-i][j] = m++;

            }

            for(int j=n-2-i; j>=i+1; j--){

                ret[j][i] = m++;

            }

        }

        if(n%2 == 1) ret[c][c] = m++;

        return ret;

    }

};

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。