Skip to content

Instantly share code, notes, and snippets.

@monhime
Created September 26, 2020 23:02
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save monhime/00884b2990adcf5ae2c0de69e0c669aa to your computer and use it in GitHub Desktop.
Save monhime/00884b2990adcf5ae2c0de69e0c669aa to your computer and use it in GitHub Desktop.
ALCBC_C.gyp
import sys
def input(): return sys.stdin.readline().rstrip()
class UnionFind():
def __init__(self, n):
self.n=n
self.parents=[-1]*n # 親(uf.find()で経路圧縮して根)の番号。根の場合は-(そのグループの要素数)
def find(self,x):
#グループの根を返す
if self.parents[x]<0:return x
else:
self.parents[x]=self.find(self.parents[x])
return self.parents[x]
def unite(self,x,y):
#要素x,yのグループを併合
x,y=self.find(x),self.find(y)
if x==y:return
if self.parents[x]>self.parents[y]:#要素数の大きい方をxに
x,y=y,x
self.parents[x]+=self.parents[y]
self.parents[y]=x #要素数が大きい方に併合
def size(self,x):
#xが属するグループの要素数
return -self.parents[self.find(x)]
def same(self,x,y):
#xとyが同じグループ?
return self.find(x)==self.find(y)
def members(self,x):
#xと同じグループに属する要素のリスト
root=self.find(x)
return [i for i in range(self.n) if self.find(i)==root]
def roots(self):
#全ての根の要素のリスト
return [i for i, x in enumerate(self.parents) if x<0]
def group_count(self):
#グループの数
return len(self.roots())
def all_group_members(self):
#各ルート要素のグループに含まれる要素のリストの辞書
return {r: self.members(r) for r in self.roots()}
def all_group_members_list(self):
#各ルート要素のグループに含まれる要素のリストのリスト
#[[0, 2], [1, 3, 4, 5]]
return list(self.all_group_members().values())
def __str__(self):
#各ルート要素のグループに含まれる要素のリストをprint()
return '\n'.join('{}: {}'.format(r,self.members(r)) for r in self.roots())
def main():
n, m = map(int,input().split())
AB_union = UnionFind(n)
for i in range(m):
a, b = map(int,input().split())
a -= 1
b -= 1
AB_union.unite(a, b)
print(AB_union.group_count() - 1)
if __name__=='__main__':
main()
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment