PythonでLake Counting (深さ優先検索)
大きさがN*Mの庭があります。そこに雨が振り、水たまりができました。水たまりは8近傍で隣接している場合につながっているとみなします。全部でいくつの水たまりがあるでしょうか?
深さ優先検索(DFS: Depth-First search)を使う。
深さ優先検索は「ある状態からはじめ、遷移できなくなるまで状態を進めていき、遷移できなくなったら一つ前の状態まで戻るということを繰り返して解を見つけます。
def debug_print(field): for xx in field: for yy in xx: print yy, print "\n", def lake_counting(field): debug_print(field) field_x_length = len(field) field_y_length = len(field[0]) lake_count = 0 def dfs(x,y): field[x][y] = '.' for dx in [-1, 0, 1]: for dy in [-1, 0, 1]: nx = x + dx ny = y + dy if (0 <= nx and nx < field_x_length and 0 <= ny and ny < field_y_length and field[nx][ny] == 'W'): dfs(nx, ny) for i in range (0, field_x_length): for j in range (0, field_y_length): if (field[i][j] == 'W'): dfs(i, j) lake_count+=1 return lake_count field = [ ['W', '.', '.', '.', '.', '.', '.', '.', '.', 'W', 'W', '.'], ['.', 'W', 'W', 'W', '.', '.', '.', '.', '.', 'W', 'W', 'W'], ['.', '.', '.', '.', 'W', 'W', '.', '.', '.', 'W', 'W', '.'], ['.', '.', '.', '.', '.', '.', '.', '.', '.', 'W', 'W', '.'], ['.', '.', '.', '.', '.', '.', '.', '.', '.', 'W', '.', '.'], ['.', '.', 'W', '.', '.', '.', '.', '.', '.', 'W', '.', '.'], ['.', 'W', '.', 'W', '.', '.', '.', '.', '.', 'W', 'W', '.'], ['W', '.', 'W', '.', 'W', '.', '.', '.', '.', '.', 'W', '.'], ['.', 'W', '.', 'W', '.', '.', '.', '.', '.', '.', 'W', '.'], ['.', '.', 'W', '.', '.', '.', '.', '.', '.', '.', 'W', '.'], ] print lake_counting(field)
実行結果
W . . . . . . . . W W . . W W W . . . . . W W W . . . . W W . . . W W . . . . . . . . . . W W . . . . . . . . . . W . . . . W . . . . . . W . . . W . W . . . . . W W . W . W . W . . . . . W . . W . W . . . . . . W . . . W . . . . . . . W . 3
プログラミングコンテストチャレンジブック [第2版] ?問題解決のアルゴリズム活用力とコーディングテクニックを鍛える?
- 作者: 秋葉拓哉,岩田陽一,北川宜稔
- 出版社/メーカー: マイナビ
- 発売日: 2012/01/28
- メディア: 単行本(ソフトカバー)
- 購入: 25人 クリック: 473回
- この商品を含むブログ (36件) を見る