結果
問題 | No.2696 Sign Creation |
ユーザー |
![]() |
提出日時 | 2024-03-23 05:06:03 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 948 bytes |
コンパイル時間 | 315 ms |
コンパイル使用メモリ | 82,228 KB |
実行使用メモリ | 90,068 KB |
最終ジャッジ日時 | 2024-12-20 12:39:30 |
合計ジャッジ時間 | 10,846 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 WA * 2 |
other | AC * 10 WA * 28 |
ソースコード
h,w,n,d=map(int,input().split())a=[[-1]*w for i in range(h)]s=[]r=list(range(n))def union(x,y):rx=root(x)ry=root(y)if rx>ry:rx,ry=ry,rxr[ry]=rxreturndef 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=[]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:rr+=[a[xx][yy]]rr=set(rr)if len(rr)==0:g1=g0+1else:g2=min(g2,g0-len(rr)+1)print(g2,g1)