LeetCode 200 島嶼的個數

2022-05-19 07:06:58 字數 822 閱讀 7881

給定乙個由'1'(陸地)和'0'(水)組成的的二維網格,計算島嶼的數量。乙個島被水包圍,並且它是通過水平方向或垂直方向上相鄰的陸地連線而成的。你可以假設網格的四個邊均被水包圍。

示例 1:

輸入:

11110

11010

11000

00000

輸出: 1

示例 2:

輸入:

11000

11000

00100

00011

輸出: 3

找到乙個值為'1'的點(島嶼),把該點地值置為'1',在它的周圍(上下左右)繼續(遞迴地)找值為'1'的點,同樣,找到後就把該點的值置為'1',直到找不到值為'1'的點,這樣就完成了一座島嶼的搜尋,計數器加一。

對二維陣列中的每乙個點執行上述操作,完成後返回計數器的值,即為島嶼的數量。

public int numislands (char grid) }}

return count;

}private void dfs (char grid, int i, int j)

}

最初看到這個題目,覺得跟《演算法》第四版上的 1.5 節 union-find 比較像,但是要實現 uf 的資料結構,感覺比較麻煩,於是使用了 dfs 。

leetcode200 島嶼個數

對方格中的每乙個點為起點進行遍歷。如果找到乙個為1的點,結果就更新。以該點為中心,搜尋四周的點 搜尋流程 如果越界,返回 如果是0,返回 向四周搜尋class solution object def numislands self,grid type grid list list str rtype...

LeetCode 200 島嶼數量

給定乙個由 1 陸地 和 0 水 組成的的二維網格,計算島嶼的數量。乙個島被水包圍,並且它是通過水平方向或垂直方向上相鄰的陸地連線而成的。你可以假設網格的四個邊均被水包圍。示例 1 輸入 11110 11010 11000 00000輸出 1 示例 2 輸入 11000 11000 00100 00...

leetcode200 島嶼數量

可以遍歷矩陣中的每個位置,如果遇到1就將與其相連的一片1都感染成2 dfs 並自增島數量。class solution object def numislands self,grid type grid list list str rtype int res 0 if not grid return...