結果
| 問題 |
No.2291 Union Find Estimate
|
| コンテスト | |
| ユーザー |
👑 |
| 提出日時 | 2023-05-10 16:49:43 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 511 ms / 2,000 ms |
| コード長 | 500 bytes |
| コンパイル時間 | 243 ms |
| コンパイル使用メモリ | 82,468 KB |
| 実行使用メモリ | 77,824 KB |
| 最終ジャッジ日時 | 2024-11-26 21:52:40 |
| 合計ジャッジ時間 | 4,303 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 18 |
ソースコード
I,J,R,O=input,int,range,print
X,T=I().split(),R(10)
W,H,N,c=J(X[0]),J(X[1]),[str(i) for i in T],1
p,e=[j for j in R(W+10)],W
def r(i):
m=p[i]
while i!=m:
p[i]=i=p[m]
m=p[i]
return i
def g(i,j):
global e
i,j=r(i),r(j)
if i>j:i,j=j,i
if i!=j:p[i],e=j,e-1
for h in R(H):
Q,D=I(),{}
for j in R(W):
q,s=Q[j],1
if q!='?':
for n in T:
if q==N[n]:
g(j,W+n)
s=0
if s:
if q in D:g(D[q],j)
else:D[q]=j
for n in T:c*=(r(W+n)==W+n)
O(pow(10,e,998244353) if c else 0)