精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

一道字節筆試題,沒有想到考察的是....

開發 前端
本篇分享的內容是字節的筆試題,字節的算法題。考察的點,可以歸納于深度優先遍歷,或者說是一道腦筋急轉彎題。

[[398239]]

大家好,我是TianTian。

分享的內容是字節的筆試題,字節的算法題。

考察的點,可以歸納于深度優先遍歷,或者說是一道腦筋急轉彎題。

題目給定一個包含 m x n 個元素的矩陣(m 行, n 列),請按照順時針螺旋順序,返回矩陣中的所有元素。

輸入:

  1.  
  2.   [ 1, 2, 3 ], 
  3.  
  4.   [ 4, 5, 6 ], 
  5.  
  6.   [ 7, 8, 9 ] 
  7.  

輸出:

  1. [1,2,3,6,9,8,7,4,5] 

思路

基本上圍繞的思路就是:一層層向里處理,按順時針依次遍歷:上、右、下、左。

其實很類似于迷宮的走法,走到格子后,判斷下一個格子,還能不能走,也就是邊界條件。遇到邊界條件后,順著上面的順序: 上、右、下、左。

所以我們可以有幾個約束條件:

  • 是不是在這個范圍內,不能超過這些范圍。
  • 這個格子是不是走過,存一下之前的狀態。
  • 記錄當前方向,抱著下一個方向是對的。

深度優先遍歷

按照深度優先遍歷思路來寫,我們可以構造常見的dfs模版:

  1. const spiralOrder = function (matrix) { 
  2.     if (matrix.length === 0) return []; 
  3.     const result = [], 
  4.         dx = [0, 1, 0, -1], 
  5.         dy = [1, 0, -1, 0], 
  6.         col = matrix.length, 
  7.         row = matrix[0].length; 
  8.     // isCheckMatrix記錄是否走過 
  9.     const isCheckMatrix = Array.from(new Array(col), () => (new Array(row).fill(false)))  
  10.     const dfs = (x, y, directionIndex) => { 
  11.           // 邏輯代碼 
  12.             // 通常這里做邏輯處理,邊界處理 
  13.         } 
  14.     }; 
  15.     dfs(0, 0, 0); 
  16.     return result 
  17. }; 

這應該就是基礎的模版,唯一不同的是,我們看dfs的三個參數,x,y,directionIndex。

x和y參數很好理解,這個directionIndex參數含義就是告訴我們當前前進的方向。

接下來,是寫我們的邏輯部分。首先確定接下來走到哪一個格子:

  1. dx = [0, 1, 0, -1] 
  2. dy = [1, 0, -1, 0] 
  3. const nextX = x + dx[directionIndex] 
  4. const nextY = y + dy[directionIndex] 

根據當前的格子所在的位置x,y我們就知道接下來要走的位置,通過directionIndex的下標索引,知道我們下一個格子的坐標。

然后就是判斷一下,邊界的情況:

  • 不能出界
  • 判斷能不能走

根據以上的信息,其實我們主要的邏輯部分就完成啦。

代碼:

  1. const spiralOrder = function (matrix) { 
  2.     if (matrix.length === 0) return []; 
  3.     const result = [], 
  4.         dx = [0, 1, 0, -1], 
  5.         dy = [1, 0, -1, 0], 
  6.         col = matrix.length, 
  7.         row = matrix[0].length; 
  8.     const isCheckMatrix = Array.from(new Array(col), () => (new Array(row).fill(false))) 
  9.     const dfs = (x, y, directionIndex) => { 
  10.         result.push(matrix[x][y]) // 存答案 
  11.         isCheckMatrix[x][y] = true // 標記走過 
  12.         for (let i = 0; i < 3; i++) { 
  13.             const nextX = x + dx[directionIndex] 
  14.             const nextY = y + dy[directionIndex] 
  15.             // 判斷邊界 
  16.             if (nextX < col && nextX >= 0 && nextY < row && nextY >= 0 && !isCheckMatrix[nextX][nextY]) { 
  17.                 dfs(nextX, nextY, directionIndex) 
  18.             } 
  19.             // 方向取余數 
  20.             directionIndex = (directionIndex + 1) % 4; 
  21.         } 
  22.     }; 
  23.     dfs(0, 0, 0); 
  24.     return result 
  25. }; 

這里我們需要對方向做余數處理。在確只有四個方向的情況,并且在這個方向不能走的情況下,嘗試下一個方向。

  1. directionIndex = (directionIndex + 1) % 4; 

優化

寫完的時候,我在想能不能優化一下,做個減枝的處理,后面發現,當前這個位置可以走的話,是不是就不能判斷其他方向了。

或者說我們可以提前走出這個循環,這里做的優化就是return 當前的處理。

代碼:

  1. const spiralOrder = function (matrix) { 
  2.     if (matrix.length === 0) return []; 
  3.     const result = [], 
  4.         dx = [0, 1, 0, -1], 
  5.         dy = [1, 0, -1, 0], 
  6.         col = matrix.length, 
  7.         row = matrix[0].length; 
  8.     const isCheckMatrix = Array.from(new Array(col), () => (new Array(row).fill(false))) 
  9.     const dfs = (x, y, directionIndex) => { 
  10.         result.push(matrix[x][y]); 
  11.         isCheckMatrix[x][y] = true 
  12.         for (let i = 0; i < 3; i++) { 
  13.             const nextX = x + dx[directionIndex] 
  14.             const nextY = y + dy[directionIndex] 
  15.             if (nextX < col && nextX >= 0 && nextY < row && nextY >= 0 && !isCheckMatrix[nextX][nextY]) { 
  16.                 return dfs(nextX, nextY, directionIndex) 
  17.             } 
  18.             directionIndex = (directionIndex + 1) % 4; 
  19.         } 
  20.     }; 
  21.     dfs(0, 0, 0); 
  22.     return result 
  23. }; 

后記

后面發現這個是一道leetcode中等的題目,題目鏈接:

螺旋矩陣: https://leetcode-cn.com/problems/spiral-matrix/

 

責任編輯:姜華 來源: TianTianUp
相關推薦

2021-04-30 08:22:36

異步求和函數

2014-04-29 14:58:24

筆試題微軟筆試題

2016-12-21 14:29:50

以太網數據中心服務器

2022-04-08 07:52:17

CSS面試題HTML

2011-03-07 13:29:52

NeusoftJava API

2024-10-11 17:09:27

2009-06-22 13:43:00

java算法

2011-05-23 11:27:32

面試題面試java

2018-03-06 15:30:47

Java面試題

2019-09-02 15:06:16

面試字節跳動算法

2009-08-11 10:12:07

C#算法

2023-02-04 18:24:10

SeataJava業務

2012-07-03 09:38:42

前端

2009-08-11 14:59:57

一道面試題C#算法

2021-01-26 13:14:14

js前端map

2021-05-31 07:55:44

smartRepeatJavaScript函數

2009-08-11 15:09:44

一道面試題C#算法

2017-11-21 12:15:27

數據庫面試題SQL

2024-03-18 13:32:11

2023-08-01 08:10:46

內存緩存
點贊
收藏

51CTO技術棧公眾號

东方伊人免费在线观看| 青青青青在线视频| 国产毛片毛片毛片毛片| 欧美午夜电影在线观看| 亚洲精品第一页| 亚洲精品久久久中文字幕| 性欧美高清come| 久久精品欧美日韩精品| 91免费欧美精品| 日本天堂在线视频| 欧美日韩一区二区三区视频播放| 91精品国产综合久久小美女| 国产精品丝袜久久久久久消防器材| 国产视频在线看| 国产成人精品亚洲日本在线桃色 | 亚洲在线成人| 久久婷婷国产麻豆91天堂| 噜噜噜在线视频| 祥仔av免费一区二区三区四区| 亚洲成人精品影院| 欧美性视频在线播放| 国产小视频在线播放| 成人免费看黄yyy456| 国产日韩在线播放| 久久夜色精品亚洲| 你懂的亚洲视频| 在线观看国产成人av片| 久久人人妻人人人人妻性色av| 国产精品久久久久久久久久齐齐| 午夜视频一区二区三区| 欧美xxxx吸乳| 777电影在线观看| 91在线精品一区二区三区| 亚洲va国产va天堂va久久| 日韩不卡高清视频| 久久久精品五月天| 2019中文在线观看| 欧美成人aaaaⅴ片在线看| 中文字幕一区二区av| 三级精品视频久久久久| 亚洲a v网站| 亚洲免费福利一区| 日韩高清人体午夜| 亚洲第一页av| 亚洲色图丝袜| 亚洲美女性生活视频| 欧美精品黑人猛交高潮| 欧美三级午夜理伦三级在线观看 | 91精品人妻一区二区三区蜜桃2| 欧美性生活一级| 欧美日韩成人高清| 做a视频在线观看| 成人在线视频国产| 91精品国产综合久久婷婷香蕉| 女同激情久久av久久| a成人v在线| 欧美丰满少妇xxxxx高潮对白| 粉色视频免费看| 精品久久久久久久久久岛国gif| 555夜色666亚洲国产免| 特种兵之深入敌后| 北条麻妃在线一区二区免费播放| 精品国精品自拍自在线| 三级视频网站在线观看| 偷拍一区二区| 国产亚洲视频在线观看| 懂色av蜜臀av粉嫩av永久| 91精品国产麻豆国产在线观看| 欧美大胆在线视频| 精品无码人妻一区二区三| 99精品国产99久久久久久福利| 欧美一级淫片播放口| 69av视频在线观看| 狠狠色丁香久久婷婷综合_中| 亚洲一区二区三区乱码aⅴ| 精品人妻aV中文字幕乱码色欲| 国产成人精品在线看| 国产一区二区三区奇米久涩| 视频在线不卡| 中文字幕高清一区| 91国在线高清视频| 日韩理论视频| 欧美精品日日鲁夜夜添| 中文字幕制服丝袜| 香蕉视频一区| 久久亚洲一区二区三区四区五区高| 国产精品 欧美激情| 一本一本久久| 国产精品吴梦梦| 六月婷婷中文字幕| 国产欧美日韩另类一区| 亚洲黄色网址在线观看| 韩国成人漫画| 日韩一区二区三区观看| 国产特黄级aaaaa片免| 天天久久综合| 日韩av三级在线观看| 一级片视频免费| 91视视频在线观看入口直接观看www| 亚洲精品成人自拍| 国产福利电影在线播放| 欧美日韩国产首页在线观看| 五月天激情小说| 国产精品99一区二区三| 欧美一区二区三区……| 国产女人18毛片水真多| 久久久精品日韩欧美| 免费观看亚洲视频| 成人看片毛片免费播放器| 精品美女在线观看| 日本黄色录像视频| 亚洲欧美日韩精品一区二区| 91免费的视频在线播放| 国产中文字幕在线视频| 午夜精品久久久久久| 色偷偷中文字幕| 精品久久91| 欧美亚洲国产日韩2020| www日本高清视频| 国产精品女主播在线观看| 成人在线免费在线观看| av成人app永久免费| 久久精品小视频| 国模私拍一区二区| 2019国产精品| 少妇人妻在线视频| 超碰精品在线观看| 欧美日本中文字幕| 国产农村妇女毛片精品久久| 国产精品视频一二三区| 国产性xxxx18免费观看视频| 57pao国产一区二区| 欧美成人网在线| 国产精品一区二区av白丝下载| 国产欧美精品在线观看| 国产男女无遮挡| 久久久久久毛片免费看 | 国产一区在线不卡| 亚洲一区二区三区精品视频| 欧美日韩在线精品一区二区三区激情综合| 日韩av一区二区在线观看| 国产精品第二十页| 成人免费av资源| 久久国产午夜精品理论片最新版本| 欧美视频二区欧美影视| 色综合色综合网色综合| 成人免费一级视频| 亚洲大片一区二区三区| 日韩av手机在线播放| 国产一区二区三区的电影| 久久久久久久久久久久久9999| 成年人黄色大片在线| 日韩成人在线观看| 精品成人无码久久久久久| 国产视频一区二区在线观看| 国产小视频精品| 日韩欧美精品| 91亚洲精品视频| 日本无删减在线| 日韩精品一区在线观看| www.99re7.com| 99国产精品久久久久久久久久 | 日韩av最新在线| 无码人妻丰满熟妇区五十路| 国产欧美一区二区精品久导航 | 福利电影一区二区| 波多野结衣家庭教师在线播放| 日韩高清影视在线观看| 国产精品第七十二页| 亚洲视频tv| 日韩精品一区二区三区在线观看 | 日韩国产一区二| 亚洲一卡二卡三卡| 一区二区三区视频播放| 欧美亚洲成人精品| 69av在线| 精品国产自在久精品国产| 国产微拍精品一区| 国产精品免费久久久久| 能看毛片的网站| 蜜桃久久av| 欧美日韩dvd| 国产91一区| 亚洲aa中文字幕| 亚洲国产欧美日本视频| 日韩天堂在线视频| 天堂在线资源网| 欧美日韩一区二区电影| 国产午夜精品一区二区理论影院 | 最新不卡av| 欧美人妖视频| 91九色蝌蚪国产| 亚洲国产欧美日本视频| 久久精品久久精品亚洲人| 色呦呦视频在线| 欧美精品免费视频| 亚洲第一精品在线观看| 亚洲私人黄色宅男| 国产男男chinese网站| 国产高清在线精品| 99久久国产宗和精品1上映| 亚洲欧美文学| 亚洲三区视频| 亚洲成aⅴ人片久久青草影院| 亚洲free性xxxx护士白浆| 亚洲黄色网址| 久久久久亚洲精品| 免费黄色网页在线观看| 亚洲精品一区二三区不卡| 国产富婆一级全黄大片| 欧美最猛性xxxxx直播| 久久久精品视频免费| 亚洲天天做日日做天天谢日日欢| 中文字幕5566| 99久久精品国产导航| 中文字幕日韩久久| 免费高清在线视频一区·| 北条麻妃69av| 精品96久久久久久中文字幕无| 亚洲在线色站| 欧美丝袜激情| 欧美精品七区| 日韩精品免费一区二区夜夜嗨| 亚洲影院在线看| 亚瑟国产精品| 国产日韩欧美在线观看| 免费观看亚洲| 日本欧美爱爱爱| 亚洲午夜天堂| 91成人在线视频| 91九色美女在线视频| 欧美高清在线视频观看不卡| а√资源新版在线天堂| www.日韩免费| 欧美精品hd| 久久精品国产成人精品| 色大18成网站www在线观看| 亚洲欧美另类自拍| 黄色影院在线播放| 亚洲深夜福利网站| 韩国三级av在线免费观看| 亚洲男人的天堂网站| 欧美美女搞黄| 亚洲视频999| freemovies性欧美| 中文字幕在线精品| 日本成人在线播放| 久久精品99无色码中文字幕| 免费网站成人| 色综合久久88色综合天天看泰| 色呦呦在线播放| 久久理论片午夜琪琪电影网| 久久99亚洲网美利坚合众国| 欧美精品videosex极品1| 91www在线| 欧美中在线观看| 天天免费亚洲黑人免费| 国产精品久久久av| 日日夜夜精品| 97人人模人人爽视频一区二区| 91在线一区| 麻豆91蜜桃| 欧美日韩一二三四| 大桥未久一区二区三区| 狠狠干成人综合网| 久久成人免费观看| 日韩电影一二三区| 一级片免费在线观看视频| 处破女av一区二区| 新91视频在线观看| 国产精品久久久久影视| 欧美日韩中文字幕在线观看| 香蕉久久一区二区不卡无毒影院| av资源免费观看| 欧美日韩国产一区| 三级网站在线看| 夜夜嗨av色一区二区不卡| 亚洲精品白浆| 日本高清不卡在线| 亚洲美女色播| 国内精品久久国产| 久久性感美女视频| 拔插拔插海外华人免费| 日日夜夜免费精品| 麻豆短视频在线观看| 国产农村妇女精品| 欧美成人aaa片一区国产精品| 日韩欧美中文免费| aaa国产视频| 亚洲性无码av在线| 国产精品186在线观看在线播放| 国产成人精品久久| 91精品啪在线观看国产爱臀 | 国产精品日日做人人爱| 综合中文字幕| 亚洲天堂电影网| 日韩午夜免费| 中文字幕一区二区在线观看视频| 99久久99久久精品免费观看| 少妇高潮在线观看| 日本精品一区二区三区高清| 午夜美女福利视频| 日韩在线欧美在线国产在线| 黄在线观看免费网站ktv| 成人免费观看网址| 欧美日韩国产传媒| 国产精品国产亚洲精品看不卡| 麻豆久久久久久久| 日韩人妻一区二区三区| 亚洲综合激情网| 91成品人影院| 国产一区二区三区在线| 极品在线视频| 国产经品一区二区| 亚洲高清影视| 日韩高清第一页| 国产欧美视频一区二区| 日本中文在线播放| 精品粉嫩超白一线天av| 麻豆tv免费在线观看| 国产精品九九久久久久久久| 午夜欧洲一区| 成年人网站免费视频| 丰满少妇久久久久久久| 一区二区视频免费看| 欧美福利视频导航| 永久免费av在线| 国产精品免费久久久| 少妇精品久久久一区二区三区 | 久久国产剧场电影| 日韩欧美黄色网址| 在线欧美日韩国产| 国产一区精品| 国产精品91久久久| 九一亚洲精品| www.xxx亚洲| 欧美激情一区二区三区蜜桃视频| 亚洲天堂五月天| 国产一区二区三区丝袜| 成人看片网站| 香蕉久久免费影视| 久久国产精品72免费观看| 国产精品视频在| 欧美日本在线播放| 九色porny丨首页在线| 成人欧美一区二区三区黑人| 午夜精品一区二区三区国产| 午夜久久福利视频| 亚洲天堂免费在线观看视频| 97人妻精品一区二区三区视频| 视频在线观看一区二区| 久久精品国产福利| 丰满女人性猛交| 国产精品亚洲成人| 日韩福利片在线观看| 日韩精品免费一线在线观看| 中文字幕一区久| 四虎永久国产精品| 国内欧美视频一区二区| 妺妺窝人体色www在线下载| 精品成人佐山爱一区二区| 欧美久久天堂| 亚洲欧美成人一区| 国产一区二区三区四区在线观看| 激情综合网五月天| 日韩av在线网址| 99久久伊人| 国产资源第一页| 99国产精品久久久久久久久久久| 日韩熟女一区二区| 久久亚洲国产成人| 美女呻吟一区| 15—17女人毛片| 亚洲精品国产高清久久伦理二区 | 一区二区三区视频免费| 亚洲18在线| ww国产内射精品后入国产| 国产欧美一区二区精品忘忧草| 99在线精品视频免费观看20| 97在线视频免费观看| 日韩精品中文字幕第1页| xxxxwww一片| 欧美自拍丝袜亚洲| 18+激情视频在线| 欧美激情论坛| 国产精品羞羞答答xxdd| 亚洲日本视频在线观看| 久久的精品视频| 精品影片在线观看的网站| 91热视频在线观看| 一本久道中文字幕精品亚洲嫩| 免费在线毛片网站| 精品在线不卡| 国产资源在线一区| 视频一区二区三区四区五区| 精品精品国产国产自在线| 四虎影视精品| 麻豆精品国产传媒| 欧美日精品一区视频| 成人一级福利|