結果
問題 |
No.2178 Payable Magic Items
|
ユーザー |
![]() |
提出日時 | 2023-11-01 19:54:38 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 270 ms / 4,000 ms |
コード長 | 722 bytes |
コンパイル時間 | 422 ms |
コンパイル使用メモリ | 81,856 KB |
実行使用メモリ | 212,128 KB |
最終ジャッジ日時 | 2024-09-25 18:01:48 |
合計ジャッジ時間 | 5,166 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 23 |
ソースコード
import sys input = sys.stdin.readline def to_num(s): ret = 0 for c in s: x = ord(c) - ord('0') ret <<= 3 ret += x return ret N, K = map(int, input().split()) st = list([to_num(input()[:-1]) for _ in [0] * N]) visited = [0] * (1 << (K * 3)) for v_start in st: if(visited[v_start] == 1): continue stk = [v_start] while(stk): v_now = stk.pop() for i in range(0, K * 3, 3): if(((v_now >> i) & 7) == 0): continue v_next = v_now - (1 << i) if(visited[v_next] == 1): continue visited[v_next] = 1 stk.append(v_next) ans = sum(visited[x] for x in st) print(ans)