給定乙個由'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...