aboutsummaryrefslogtreecommitdiff
path: root/src/uk/ac/ox/cs/pagoda/util/UFS.java
blob: 0869fb724b72afe9083fb4a37cfd27cb91a7b07e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
package uk.ac.ox.cs.pagoda.util;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

public class UFS<T> {
	
	private Map<T, T> groups = new HashMap<T, T>();

	public boolean merge(T t1, T t2) {
		t1 = find(t1); t2 = find(t2);
		if (t1.equals(t2)) return false;
		if (t2.toString().contains("cs.ox.ac.uk"))
			groups.put(t2, t1); 
		else 
			groups.put(t1, t2); 
		return true; 
	}
	
	public Set<T> keySet() {
		return groups.keySet(); 
	}

	public T find(T u) {
		T v, w = u;
		while ((v = groups.get(u)) != null) 
			u = v; 
		
		while ((v = groups.get(w)) != null) {
			groups.put(w, u);
			w = v; 
		}
		
		return u; 
	}
	
	public void clear() {
		groups.clear();
	}

	public boolean isEmpty() {
		return groups.isEmpty();
	}
}