首页
/
每日頭條
/
生活
/
二維數組簡化寫法
二維數組簡化寫法
更新时间:2026-07-02 13:32:41

二維數組簡化寫法(如何螺旋遍曆二維數組)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
推荐阅读
早上空腹喝水不宜超過幾點
早上空腹喝水不宜超過幾點
衆所周知,水是生命之源,飲水量充足,掌握正确飲水方法,需要的水分不斷獲取,可以保持循環良好,代謝正常,還在一定程度上保護膀胱、尿路以及腎髒。因此,在喝水這方面可不能馬虎,相關細節要注意。有不少人早上起床之後會空腹喝水,這種行為是好是壞?經過...
2026-07-02
上古密約播出時間
上古密約播出時間
上古密約播出時間?電視劇《山海經之上古密約》将于2020年02月09日起在湖南衛視上映播出《上古密約》是由扈耀之執導,吳磊、宋祖兒領銜主演,王俊凱特邀出演,郭俊辰、張齡心、鄭凱,高仁友情出演,宣言、夏若妍、劉芷微、章煜奇、劉芮僑主演的古裝神...
2026-07-02
哪些數的立方根是整數
哪些數的立方根是整數
42是對生命、宇宙和銀河漫遊指南中所有問題的答案。馬丁·弗裡曼在2005年的電影中扮演亞瑟·但丁。9月11日消息,如果你是科幻愛好者,看到42号,你一定會笑。衆所周知,42是對生命、宇宙和《銀河系漫遊指南》中所有問題的答案。該書的作者、已故...
2026-07-02
一分鐘熟記科目三模拟燈光教程
一分鐘熟記科目三模拟燈光教程
,
2026-07-02
為全縣生态環境保護工作保駕護航
為全縣生态環境保護工作保駕護航
為全縣生态環境保護工作保駕護航?近年來,為了紮緊生态環境保護的制度籠子,許多地方進行了諸多有益嘗試作為我國首批3個國家生态文明試驗區之一,江西從2020年開始,成立了由副省長任組長的省生态環境保護督察工作領導小組,設置了省督察辦,并按照區域...
2026-07-02
Copyright 2023-2026 - www.tftnews.com All Rights Reserved