一魚多吃 用BFS來列出拜訪路徑 Diagonal Traverse II_Leetcode#1424

更新於 發佈於 閱讀時間約 4 分鐘

題目敘述

題目會給我們一個不規則排列的二維陣列,要求我們列出從起點出發,走次對角線方向,由左下到右上逐層拜訪的路徑。

題目的原文敘述


測試範例

Example 1:

raw-image
Input: nums = [[1,2,3],[4,5,6],[7,8,9]]
Output: [1,4,2,7,5,3,8,6,9]

Example 2:

raw-image
Input: nums = [[1,2,3,4,5],[6,7],[8],[9,10,11],[12,13,14,15,16]]
Output: [1,6,2,8,7,3,9,4,12,10,5,13,11,14,15,16]

約束條件

Constraints:

  • 1 <= nums.length <= 10^5
  • 1 <= nums[i].length <= 10^5
  • 1 <= sum(nums[i].length) <= 10^5
  • 1 <= nums[i][j] <= 10^5

演算法

除了傳統的次對角線方向總合當作鍵值的字典演算法之外,還有一個高效率的BFS演算法。

我們可以這樣想,把左上角(0, 0)這個座標當作起點。依循BFS的原則,往右下角擴散


假設當下拜訪到的座標為(x, y)

當現在位在最左邊的column時,把下方的鄰居(x, y+1)推入BFS queue。

當現在不在最右邊的column時,把右邊的鄰居(x+1, y)推入BFS queue。


接著,把拜訪到的元素值記錄下來,就是最終答案。

從起點 左上角的1出發

拜訪1 的時侯,加入鄰居 4, 2

拜訪4 的時侯,加入鄰居 7, 5

拜訪2 的時侯,加入鄰居 3

拜訪7 的時侯,加入鄰居 8

拜訪5 的時侯,加入鄰居 6

拜訪3 已經抵達最右邊的column

拜訪8 的時侯,加入鄰居 9

拜訪6 已經抵達最右邊的column

拜訪9 已經抵達最右邊的column


最後,整個次對角線的拜訪路徑就是

1, 4, 2, 7, 5, 3, 8, 6, 9


程式碼

class Solution:
 def findDiagonalOrder(self, nums: List[List[int]]) -> List[int]:
  
  # Height of input 2D array
  H = len(nums)

  # 2D (x, y) coordination of each grid
  traversal_q = deque( [(0, 0)] )

  # record of traversal path
  record = []

  # Launch BFS traversal from staring point (0, 0)
  while traversal_q:
   
   ## Add current grid to record of traversal path
   x, y = traversal_q.popleft()
   record.append( nums[y][x] )

   ## Add neighbor below on the leftmost column
   if x == 0 and ( (y + 1) < H ):
    traversal_q.append( (x, y+1) )
   
   
   ## Add neighbor on right hand side
   
   # Get width of current row dynamically
   cur_width = len( nums[y] )

   if x + 1 < cur_width:
    traversal_q.append( (x+1, y) )

  return record

關鍵知識點

本題目切忌先入為主,把題目當成方陣或矩陣。
這題的輸入其實是不規則的二維陣列


可以想到BFS演算法,把矩陣的每個格子點視為一個節點相鄰的節點有一條邊相連

我們可以這樣想,把左上角(0, 0)這個座標當作起點。依循BFS廣度優先的原則,往右下角擴散

最後整個BFS拜訪順序的軌跡,就是答案。


Reference:

[1] Python O(HW) on BFS and neighbor growing [w/ Visualization] - Diagonal Traverse II - LeetCode

avatar-img
91會員
425內容數
由有業界實戰經驗的演算法工程師, 手把手教你建立解題的框架, 一步步寫出高效、清晰易懂的解題答案。 著重在讓讀者啟發思考、理解演算法,熟悉常見的演算法模板。 深入淺出地介紹題目背後所使用的演算法意義,融會貫通演算法與資料結構的應用。 在幾個經典的題目融入一道題目的多種解法,或者同一招解不同的題目,擴展廣度,並加深印象。
留言0
查看全部
avatar-img
發表第一個留言支持創作者!
題目會給我們一個routes 陣列,裡面都是分別代表每一條公車路線所對應的公車站編號。 題目要求我們計算出,從起點站source到終點站target的最精簡公車路線搭乘次數是幾次? 也就是說,就是在最少轉乘的前提下,旅途中需要搭乘幾條公車路線?
題目會給我們一個pair陣列,裡面都是原本陣列相鄰元素形成的pair,順序已經被打散。 要求我們從pair陣列重建出原本的陣列。 答案可能有不只一組,任選一組回傳即可。
題目會給定我們兩個點座標,分別是起點和終點。 另外,還有一個參數t,代表時間限制。 從起點出發之後,每一秒鐘,我們必須選擇一個N8 8連通的方向,往鄰居的格子點移動。(題目有特別強調,每一秒必須強制移動到下一個格子點,不能停留在原地) 請問我們能不能在時間限制內,從起點走到終點?
題目會給一顆二元樹,要求我們計算節點值 和 子樹平均值相等的node有幾個。
題目會給我們一顆二元樹的根結點,要求我們找出每一層最大的節點值。
題目會給我們節點總數目n、左子樹的關係陣列、右子樹的關係陣列,要求我們驗證在給定的條件下,能不能構成一顆合法的二元樹。
題目會給我們一個routes 陣列,裡面都是分別代表每一條公車路線所對應的公車站編號。 題目要求我們計算出,從起點站source到終點站target的最精簡公車路線搭乘次數是幾次? 也就是說,就是在最少轉乘的前提下,旅途中需要搭乘幾條公車路線?
題目會給我們一個pair陣列,裡面都是原本陣列相鄰元素形成的pair,順序已經被打散。 要求我們從pair陣列重建出原本的陣列。 答案可能有不只一組,任選一組回傳即可。
題目會給定我們兩個點座標,分別是起點和終點。 另外,還有一個參數t,代表時間限制。 從起點出發之後,每一秒鐘,我們必須選擇一個N8 8連通的方向,往鄰居的格子點移動。(題目有特別強調,每一秒必須強制移動到下一個格子點,不能停留在原地) 請問我們能不能在時間限制內,從起點走到終點?
題目會給一顆二元樹,要求我們計算節點值 和 子樹平均值相等的node有幾個。
題目會給我們一顆二元樹的根結點,要求我們找出每一層最大的節點值。
題目會給我們節點總數目n、左子樹的關係陣列、右子樹的關係陣列,要求我們驗證在給定的條件下,能不能構成一顆合法的二元樹。
你可能也想看
Google News 追蹤
Thumbnail
隨著理財資訊的普及,越來越多台灣人不再將資產侷限於台股,而是將視野拓展到國際市場。特別是美國市場,其豐富的理財選擇,讓不少人開始思考將資金配置於海外市場的可能性。 然而,要參與美國市場並不只是盲目跟隨標的這麼簡單,而是需要策略和方式,尤其對新手而言,除了選股以外還會遇到語言、開戶流程、Ap
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
每天練走有三個方向三條路。 第一條路是走到巷口的便利商店大約110公尺,車多鄰居多,遇見了總要寒暄好久腳怎麼了,也是唯一離我最近可購物處,除非要買便利店的東西否則我不太會首選走這條路。朋友來探視曾約在便利商店過,裡面只有六個坐位經常滿座且沒廁所,想
Thumbnail
以往出國的時候,每到一座新的城市,第一件事,一定是先去遊客中心拿地圖,問清楚想去的景點的方向、前往方式,甚至連餐廳、車票、住宿,能想到的,都要問好問滿。在手機連網不發達的年代,看著地圖照著走,迷路人或是不確定方向,畢竟「路是長在嘴上的」。
隨機漫步看似簡單,但卻是模擬許多自然界現象的基礎,相關的觀念及程式實作方式,對於瞭解亂數、機率、Perlin noise等工具,會有相當大的幫助。
Thumbnail
本篇文章介紹了路徑的概念和兩種不同的路徑運用。這些知識對於網頁開發非常重要,能夠幫助網站開發者更好地管理資源文件的位置。文章通過實際例子和相對路徑的範例來解釋這些概念。希望通過這篇文章,讀者能夠清楚地瞭解路徑的概念,並在日後的開發中能夠靈活運用。
Thumbnail
迷途的羔羊 總是需要一個方向的指引 困難的時候 在前方無論 多艱難 總要學會向前行 而不是步步退行 又回到那原點徘迴不定 行走路途 路面崎嶇不平 腳步稍稍不穩 容易跌撞 但在這一條路上 也在親自走過了 才明白 原來這一些 都是多麼的不容易....
Thumbnail
隨著理財資訊的普及,越來越多台灣人不再將資產侷限於台股,而是將視野拓展到國際市場。特別是美國市場,其豐富的理財選擇,讓不少人開始思考將資金配置於海外市場的可能性。 然而,要參與美國市場並不只是盲目跟隨標的這麼簡單,而是需要策略和方式,尤其對新手而言,除了選股以外還會遇到語言、開戶流程、Ap
Thumbnail
嘿,大家新年快樂~ 新年大家都在做什麼呢? 跨年夜的我趕工製作某個外包設計案,在工作告一段落時趕上倒數。 然後和兩個小孩過了一個忙亂的元旦。在深夜時刻,看到朋友傳來的解籤網站,興致勃勃熬夜體驗了一下,覺得非常好玩,或許有人玩過了,但還是想寫上來分享紀錄一下~
Thumbnail
每天練走有三個方向三條路。 第一條路是走到巷口的便利商店大約110公尺,車多鄰居多,遇見了總要寒暄好久腳怎麼了,也是唯一離我最近可購物處,除非要買便利店的東西否則我不太會首選走這條路。朋友來探視曾約在便利商店過,裡面只有六個坐位經常滿座且沒廁所,想
Thumbnail
以往出國的時候,每到一座新的城市,第一件事,一定是先去遊客中心拿地圖,問清楚想去的景點的方向、前往方式,甚至連餐廳、車票、住宿,能想到的,都要問好問滿。在手機連網不發達的年代,看著地圖照著走,迷路人或是不確定方向,畢竟「路是長在嘴上的」。
隨機漫步看似簡單,但卻是模擬許多自然界現象的基礎,相關的觀念及程式實作方式,對於瞭解亂數、機率、Perlin noise等工具,會有相當大的幫助。
Thumbnail
本篇文章介紹了路徑的概念和兩種不同的路徑運用。這些知識對於網頁開發非常重要,能夠幫助網站開發者更好地管理資源文件的位置。文章通過實際例子和相對路徑的範例來解釋這些概念。希望通過這篇文章,讀者能夠清楚地瞭解路徑的概念,並在日後的開發中能夠靈活運用。
Thumbnail
迷途的羔羊 總是需要一個方向的指引 困難的時候 在前方無論 多艱難 總要學會向前行 而不是步步退行 又回到那原點徘迴不定 行走路途 路面崎嶇不平 腳步稍稍不穩 容易跌撞 但在這一條路上 也在親自走過了 才明白 原來這一些 都是多麼的不容易....