結果
問題 | No.421 しろくろチョコレート |
ユーザー |
|
提出日時 | 2017-04-27 17:13:56 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 151 ms / 2,000 ms |
コード長 | 1,156 bytes |
コンパイル時間 | 170 ms |
コンパイル使用メモリ | 82,108 KB |
実行使用メモリ | 77,760 KB |
最終ジャッジ日時 | 2024-09-23 07:15:20 |
合計ジャッジ時間 | 6,284 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 65 |
ソースコード
from itertools import productdx = [ 0, 1, 0, -1 ]dy = [ 1, 0, -1, 0 ]N, M = map( int, input().split() )G = [ input() for i in range( N ) ]adj = [ [] for i in range( N * M ) ]for i in range( N ):for j in range( M ):if G[ i ][ j ] != 'w': continuefor di in range( 4 ):ni, nj = i + dx[ di ], j + dy[ di ]if not ( 0 <= ni and ni < N and 0 <= nj and nj < M ): continueif G[ ni ][ nj ] == '.': continueadj[ i * M + j ].append( ni * M + nj )def find_mate( u, bf, vis = None ):if vis is None:vis = [ False for i in range( N * M ) ]for v in adj[ u ]:if vis[ v ]: continuevis[ v ] = Trueif bf[ v ] == -1 or find_mate( bf[ v ], bf, vis ):bf[ v ] = ureturn Truereturn Falsebf = [ -1 for i in range( N * M ) ]match_cnt = 0for i in range( 0, N * M ):if G[ i // M ][ i % M ] != 'w': continuematch_cnt += find_mate( i, bf )rw = sum( G[ i ][ j ] == 'w' for i, j in product( range( N ), range( M ) ) ) - match_cntrb = sum( G[ i ][ j ] == 'b' for i, j in product( range( N ), range( M ) ) ) - match_cntprint( match_cnt * 100 + min( rw, rb ) * 10 + abs( rw - rb ) )