spiral-matrix-ii[螺旋數(shù)組]

題目描述

Given an integer n, generate a square matrix filled with elements from 1 to n 2 in spiral order.
For example,
Given n =3,
You should return the following matrix:
[
[ 1, 2, 3 ],
[ 8, 9, 4 ],
[ 7, 6, 5 ]
]

  • 思路
    螺旋保存二維數(shù)組值。
    設(shè)置上、右、下、左四個變量,然后每次循環(huán)填數(shù)并更新對應(yīng)的變量即可。
public class Solution {
    public int[][] generateMatrix(int n) {
        int[][] map = new int[n][n];
        if(n <= 0)
            return map;
        
        int num = 1;
        int up = 0;
        int right = n-1;
        int down = n-1;
        int left = 0;
        while(num <= n*n){
            for(int i=up; i<=right; i++){
                map[up][i] = num;
                num ++;
            }
            up ++;
            
            for(int i=up; i<=down; i++){
                map[i][right] = num;
                num ++;
            }
            right --;
            
            for(int i=right; i>=left; i--){
                map[down][i] = num;
                num ++;
            }
            down --;
            
            for(int i=down; i>=up; i--){
                map[i][left] = num;
                num ++;
            }
            left ++;
        }
        
        return map;
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容