結果
問題 | No.2696 Sign Creation |
ユーザー |
![]() |
提出日時 | 2024-03-23 05:09:01 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 1,027 bytes |
コンパイル時間 | 356 ms |
コンパイル使用メモリ | 82,400 KB |
実行使用メモリ | 159,160 KB |
最終ジャッジ日時 | 2024-12-20 12:39:47 |
合計ジャッジ時間 | 15,620 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))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)