首页
/
每日頭條
/
生活
/
二維數組簡化寫法
二維數組簡化寫法
更新时间:2025-11-03 20:53:15

二維數組簡化寫法(如何螺旋遍曆二維數組)1

作者 | 小灰

來源 | 程序員小灰(ID:chengxuyuanxiaohui)

二維數組簡化寫法(如何螺旋遍曆二維數組)2

二維數組簡化寫法(如何螺旋遍曆二維數組)3

第二天

二維數組簡化寫法(如何螺旋遍曆二維數組)4

二維數組簡化寫法(如何螺旋遍曆二維數組)5

二維數組簡化寫法(如何螺旋遍曆二維數組)6

什麼意思呢?我們來舉個例子,給定下面這樣一個二維數組:

二維數組簡化寫法(如何螺旋遍曆二維數組)7

我們需要從左上角的元素1開始,按照順時針進行螺旋遍曆,一直遍曆完所有的元素,遍曆的路徑就像下圖一樣:

二維數組簡化寫法(如何螺旋遍曆二維數組)8

經過這樣的遍曆,返回的元素結果如下:

1,2,3,4,5,10,15,20,19,18,17,16,11,6,7,8,9,14,13,12

二維數組簡化寫法(如何螺旋遍曆二維數組)9

二維數組簡化寫法(如何螺旋遍曆二維數組)10

二維數組簡化寫法(如何螺旋遍曆二維數組)11

回公司後

二維數組簡化寫法(如何螺旋遍曆二維數組)12

二維數組簡化寫法(如何螺旋遍曆二維數組)13

二維數組簡化寫法(如何螺旋遍曆二維數組)14

二維數組簡化寫法(如何螺旋遍曆二維數組)15

二維數組簡化寫法(如何螺旋遍曆二維數組)16

二維數組簡化寫法(如何螺旋遍曆二維數組)17

二維數組簡化寫法(如何螺旋遍曆二維數組)18

二維數組簡化寫法(如何螺旋遍曆二維數組)19

二維數組簡化寫法(如何螺旋遍曆二維數組)20

二維數組簡化寫法(如何螺旋遍曆二維數組)21

二維數組簡化寫法(如何螺旋遍曆二維數組)22

二維數組簡化寫法(如何螺旋遍曆二維數組)23

二維數組簡化寫法(如何螺旋遍曆二維數組)24

二維數組簡化寫法(如何螺旋遍曆二維數組)25

第1層

從左到右遍曆“上邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)26

從上到下遍曆“右邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)27

從右到左遍曆“下邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)28

從下到上遍曆“左邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)29

第2層

從左到右遍曆“上邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)30

從上到下遍曆“右邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)31

從右到左遍曆“下邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)32

從下到上遍曆“左邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)33

第3層

從左到右遍曆“上邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)34

從上到下遍曆“右邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)35

從右到左遍曆“下邊”:

二維數組簡化寫法(如何螺旋遍曆二維數組)36

第三層的“左邊”已無需遍曆,二維數組到此遍曆完畢。

二維數組簡化寫法(如何螺旋遍曆二維數組)37

二維數組簡化寫法(如何螺旋遍曆二維數組)38

二維數組簡化寫法(如何螺旋遍曆二維數組)39

二維數組簡化寫法(如何螺旋遍曆二維數組)40

二維數組簡化寫法(如何螺旋遍曆二維數組)41

二維數組簡化寫法(如何螺旋遍曆二維數組)42

二維數組簡化寫法(如何螺旋遍曆二維數組)43

public class SpiralOrder {

public static List<Integer> spiralOrder(int[][] matrix) {

List<Integer> list = new ArrayList<Integer>;

//當二維數組是空或任何一個維度是0,直接返回

if (matrix == || matrix.length == 0 || matrix[0].length == 0) {

return list;

}

//m是矩陣的行數

int m = matrix.length;

//n是矩陣的列數

int n = matrix[0].length;

//大循環,從外向内逐層遍曆矩陣

for(int i=0; i<(Math.min(m, n) 1)/2; i ) {

//從左到右遍曆“上邊”

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

list.add(matrix[i][j]);

}

//從上到下遍曆“右邊”

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

list.add(matrix[j][(n-1)-i]);

}

//從右到左遍曆“下邊”

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

list.add(matrix[(m-1)-i][(n-1)-j]);

}

//從下到上遍曆“左邊”

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

list.add(matrix[(m-1)-j][i]);

}

}

return list;

}

public static void main(String[] args) {

int matrix = {

{ 1, 2, 3, 4, 5 },

{ 6, 7, 8, 9, 10 },

{ 11, 12, 13, 14, 15 },

{ 16, 17, 18, 19, 20 }

};

int matrix2 = {

{ 1, 2, 3, 4, 5 },

{ 6, 7, 8, 9, 10 },

{ 11, 12, 13, 14, 15 },

{ 16, 17, 18, 19, 20 },

{ 21, 22, 23, 24, 25 }

};

List<Integer> resultList1 = spiralOrder(matrix);

System.out.println(Arrays.toString(resultList1.toArray));

List<Integer> resultList2 = spiralOrder(matrix2);

System.out.println(Arrays.toString(resultList2.toArray));

}

}

在上面的代碼中,一個大循環當中包含了4個小循環。大循環控制了每一層的遍曆,4個小循環分别實現了同一層上邊、右邊、下邊,左邊的遍曆。

當遍曆到最内層時,4個小循環并不會全都執行,比如測試代碼中matrix2的最内層隻有一個元素13,那麼執行完第1個小循環,就不會再進入後面3個小循環:

二維數組簡化寫法(如何螺旋遍曆二維數組)44

二維數組簡化寫法(如何螺旋遍曆二維數組)45

二維數組簡化寫法(如何螺旋遍曆二維數組)46

二維數組簡化寫法(如何螺旋遍曆二維數組)47

二維數組簡化寫法(如何螺旋遍曆二維數組)48

二維數組簡化寫法(如何螺旋遍曆二維數組)49

二維數組簡化寫法(如何螺旋遍曆二維數組)50

點分享

二維數組簡化寫法(如何螺旋遍曆二維數組)51

二維數組簡化寫法(如何螺旋遍曆二維數組)52

,
Comments
Welcome to tft每日頭條 comments! Please keep conversations courteous and on-topic. To fosterproductive and respectful conversations, you may see comments from our Community Managers.
Sign up to post
Sort by
Show More Comments
推荐阅读
神仙草長什麼樣子
神仙草長什麼樣子
神仙草長什麼樣子?叢生型多年生草本,高30-90厘米,全株被向下稍弧曲的硬毛和短伏毛根發達、主根粗壯,淡紫褐色莖數條,直立或斜升,有分枝基生葉通常50-80片,最多可達200片,具長柄,葉片帶狀披針形、卵狀披針形至卵形,長30-60厘米,寬...
2025-11-03
鐵闆鱿魚的做法是怎樣的
鐵闆鱿魚的做法是怎樣的
鐵闆鱿魚的做法是怎樣的?食材:鱿魚400g,蚝油适量,食鹽适量,孜然适量,辣椒粉适量,雞精适量,洋蔥适量,黑胡椒粉适量,油适量,接下來我們就來聊聊關于鐵闆鱿魚的做法是怎樣的?以下内容大家不妨參考一二希望能幫到您!鐵闆鱿魚的做法是怎樣的食材:...
2025-11-03
夢到做糖餅好不好
夢到做糖餅好不好
夢到做糖餅好不好?男人夢見做糖餅是什麼意思?這說明一週的開始就由保持愉快心情出發以讓人愉快的事最優先,耗時又令人厭煩的工作就先丟到一邊吧不過如果是預定好的行程、計劃就最好不要随意變更了,不然可能會發生難以處理的狀況,該決斷的時候不要猶豫,迅...
2025-11-03
刺猬紫檀最簡單鑒定
刺猬紫檀最簡單鑒定
刺猬紫檀最簡單鑒定?辨色刺猬紫檀材身顔色呈黃褐色,常帶有紫紅色條紋,我來為大家科普一下關于刺猬紫檀最簡單鑒定?以下内容希望對你有幫助!刺猬紫檀最簡單鑒定辨色。刺猬紫檀材身顔色呈黃褐色,常帶有紫紅色條紋。試重。同體積的黃花梨家具,刺猬紫檀家具...
2025-11-03
巫峽之水能覆舟若比人心是安流的意思
巫峽之水能覆舟若比人心是安流的意思
巫峽之水能覆舟若比人心是安流的意思?巫峽的水能夠使行經其間的船隻翻覆,但是如果和人心比較起來,巫峽的水反而成了波瀾不起的川流了,下面我們就來說一說關于巫峽之水能覆舟若比人心是安流的意思?我們一起去了解并探讨一下這個問題吧!巫峽之水能覆舟若比...
2025-11-03
Copyright 2023-2025 - www.tftnews.com All Rights Reserved