結果
問題 | No.2696 Sign Creation |
ユーザー |
![]() |
提出日時 | 2024-03-23 05:31:51 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,041 bytes |
コンパイル時間 | 174 ms |
コンパイル使用メモリ | 82,008 KB |
実行使用メモリ | 156,524 KB |
最終ジャッジ日時 | 2024-12-20 12:40:44 |
合計ジャッジ時間 | 12,733 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 WA * 1 |
other | AC * 19 WA * 18 TLE * 1 |
ソースコード
h,w,n,d=map(int,input().split())a=[[-1]*w for i in range(h)]s=[]r=list(range(n))v=[1]*ndef union(x,y):rx=root(x)ry=root(y)if rx>ry:rx,ry=ry,rxr[ry]=rxv[rx]+=v[ry]returndef root(x):p=xl=[p]while r[p]!=p:p=r[p]l.append(p)for p in l:r[p]=l[-1]return r[x]dxdy=[]for dx in range(-d,d+1):for dy in range(-d,d+1):if 1<=abs(dx)+abs(dy)<=d:dxdy+=[(dx,dy)]for i in range(n):x,y=map(int,input().split())x-=1y-=1a[x][y]=is+=[(x,y)]for dx,dy in dxdy:xx=x+dxyy=y+dyif 0<=xx<h and 0<=yy<w and a[xx][yy]!=-1:union(i,a[xx][yy])for i in range(n):x,y=s[i]a[x][y]=root(i)g0=len(set([r[i] for i in range(n) if v[i]>1]))g1=g0g2=g0for x in range(h):for y in range(w):if a[x][y]==-1:rr=[]f=0for dx,dy in dxdy:xx=x+dxyy=y+dyif 0<=xx<h and 0<=yy<w and a[xx][yy]!=-1:if v[a[xx][yy]]>1:rr+=[a[xx][yy]]else:f=1rr=set(rr)if len(rr)==0:g1=g0+felse:g2=min(g2,g0-len(rr)+1)print(g2,g1)