| Total Complexity | 7 |
| Total Lines | 27 |
| Duplicated Lines | 0 % |
| Changes | 1 | ||
| Bugs | 0 | Features | 0 |
| 1 | from abc import ABCMeta, abstractmethod |
||
| 39 | class QuickUnion(UnionFind): |
||
| 40 | id = None |
||
| 41 | sizes = None |
||
| 42 | |||
| 43 | def __init__(self, capacity): |
||
| 44 | self.id = [i for i in range(capacity)] |
||
| 45 | self.sizes = [1] * capacity |
||
| 46 | |||
| 47 | def root(self, v): |
||
| 48 | while v != self.id[v]: |
||
| 49 | self.id[v] = self.id[self.id[v]] # path compression |
||
| 50 | v = self.id[v] |
||
| 51 | return v |
||
| 52 | |||
| 53 | def connected(self, v, w): |
||
| 54 | return self.root(v) == self.root(w) |
||
| 55 | |||
| 56 | def union(self, v, w): |
||
| 57 | vroot = self.root(v) |
||
| 58 | wroot = self.root(w) |
||
| 59 | |||
| 60 | if self.sizes[vroot] > self.sizes[wroot]: |
||
| 61 | self.id[wroot] = vroot |
||
| 62 | self.sizes[vroot] += self.sizes[wroot] |
||
| 63 | else: |
||
| 64 | self.id[vroot] = wroot |
||
| 65 | self.sizes[wroot] += self.sizes[vroot] |
||
| 66 |