結果
問題 | No.2696 Sign Creation |
ユーザー |
![]() |
提出日時 | 2024-03-23 05:12:52 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,060 bytes |
コンパイル時間 | 536 ms |
コンパイル使用メモリ | 82,244 KB |
実行使用メモリ | 157,628 KB |
最終ジャッジ日時 | 2024-12-20 12:40:20 |
合計ジャッジ時間 | 16,107 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 WA * 1 |
other | AC * 14 WA * 23 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]for i in range(n):x,y=map(int,input().split())x-=1y-=1a[x][y]=is+=[(x,y)]for dx in range(-d,d+1):for dy in range(-d,d+1):xx=x+dxyy=y+dyif 0<=xx<h and 0<=yy<w and abs(dx)+abs(dy)<=d 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 in range(-d,d+1):for dy in range(-d,d+1):xx=x+dxyy=y+dyif 0<=xx<h and 0<=yy<w and abs(dx)+abs(dy)<=d 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)