首页
/
每日頭條
/
生活
/
二維數組簡化寫法
二維數組簡化寫法
更新时间:2026-05-30 12:42:37

二維數組簡化寫法(如何螺旋遍曆二維數組)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-05-30
觀賞魚養殖技術與注意事項
觀賞魚養殖技術與注意事項
觀賞魚非常好看,但是觀賞魚養殖不是很容易。今天小編跟大家分享觀賞魚養殖技術大全,一起開看看吧。觀賞魚養殖技術一:水1、水源(1)自來水:自來水是我們日常生活使用的生活用水,來源方便易得,它經過一定的技術處理後,是淡水觀賞魚較佳的飼養用水。自...
2026-05-30
行測數學速算口訣
行測數學速算口訣
行測數學速算口訣?行測中常見的“往返運動問題”,也稱為“等距離平均速度問題”由于涉及到的題幹中兩地間的距離是不變的,所以這個公式為:,下面我們就來說一說關于行測數學速算口訣?我們一起去了解并探讨一下這個問題吧!行測數學速算口訣行測中常見的“...
2026-05-30
四大名著的四本書分别叫什麼
四大名著的四本書分别叫什麼
《紅樓夢》、《西遊記》、《水浒傳》、《三國演義》,中國古代四大名著家喻戶曉,至今仍然令人回味無窮。可少有人知的是,原本我國并非四大名著,而是六大名著。隻是随着不同時代的價值觀取向發生改變,直到建國後,名著也從六大變成了四大。那麼被删掉的兩本...
2026-05-30
爬山發現一個野果樹
爬山發現一個野果樹
小時候在農村山坡下經常采摘野果,像拐棗、山莓、金櫻子、野山柿、山稔子、野葡萄、桑葚、野山楂等野果就有不少了,而我最喜歡的野果還是山莓,它有着通紅的顔色,果子和草莓的形狀差不多,個頭也一樣大。山莓有時候會在草叢裡生長,在幹旱的夏季土壤裡水分比...
2026-05-30
Copyright 2023-2026 - www.tftnews.com All Rights Reserved