首页
/
每日頭條
/
生活
/
二維數組簡化寫法
二維數組簡化寫法
更新时间:2024-12-21 20:44:42

二維數組簡化寫法(如何螺旋遍曆二維數組)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
推荐阅读
李小龍是怎麼成為一個武術家的
李小龍是怎麼成為一個武術家的
1973年7月20日,年輕的李小龍突然離世,至今已經48周年了。#李小龍#李小龍是為人熟知的功夫巨星,他對中國功夫和中國武術,以及對功夫電影的影響都是無能人比的。#李小龍究竟有多厲害#“天下武功,唯快不破”,這句話是李小龍功夫的最好诠釋...
2024-12-21
瑪莎拉蒂ghibli啥時候換代
瑪莎拉蒂ghibli啥時候換代
上世紀六十年代,以賽車運動起家的瑪莎拉蒂就推出了四門運動轎車Quattroporte,并曆經六代産品延續至今。一家傳統高性能跑車制造商擁有如此包容的心态,這也不難理解瑪莎拉蒂在超跑品牌中率先制造SUV,以及把Ghibli從第一代的雙門跑車、...
2024-12-21
童年看過的機器人
童年看過的機器人
導讀:對于喜歡動漫的人來說,動漫仿佛是種文學,是一種文化思想。其實也的确是這樣,這個世界是多元化的,所以在動漫的世界中也同樣存在着這個道理。從動漫最初的故事童話故事開始講起來,到現在有着數十年的曆史,其實動漫就是新時代的童話故事才對。同時動...
2024-12-21
17款現代悅納試駕
17款現代悅納試駕
當我把這輛車開上路,時不時會有人對着它指指點點,讨論一番。在停車或洗車的時候也會有人過來問我:“哥們,這是什麼車,是進口的嗎?這車模樣兒不錯嘿!”“哦,這是台灣的一個汽車品牌,叫納智捷。”納智捷是台灣裕隆集團與東風集團以及浙江中譽集團三家合...
2024-12-21
用毛筆書寫的錄取通知書
用毛筆書寫的錄取通知書
來源:【中國教育報】見字如面!#陝西師範大學2022毛筆手寫錄取通知書開筆#今年又火了!不少網友感歎,連續16年毛筆手寫錄取通知書,誠意滿滿!近日,各大高校開始派送今年的大學錄取通知書,其中不少通知書創意滿滿,寄托着對于即将踏進大學校園的學...
2024-12-21
Copyright 2023-2024 - www.tftnews.com All Rights Reserved