-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSortedMap2.java
64 lines (50 loc) · 1.89 KB
/
SortedMap2.java
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
import java.util.Comparator;
import java.util.SortedMap;
import java.util.TreeMap;
public class SortedMap2 {
//Comparator to sort TreeMap by values
public static Comparator<Object> valueComparator = new Comparator<>() {
@Override
public int compare(Object k1, Object k2) {
if (k1.hashCode() == k2.hashCode())
{
return 0;
}
else if (k1.hashCode() > k2.hashCode())
{
return 1;
}
else
{
return -1;
}
}
public String toString() {
return "Value Compared";
}
};
public static void main(String[] args) {
//Create a TreeMap using valueComparator
SortedMap<String,Integer> sortedMap= new TreeMap<>(valueComparator);
// Add key-value pairs to TreeMap
sortedMap.put("a", 10);
sortedMap.put("c", 30);
sortedMap.put("b", 20);
sortedMap.put("d", 40);
sortedMap.put("e", 50);
sortedMap.put("f", 60);
sortedMap.put("g", 70);
sortedMap.put("h", 80);
//Print the TreeMap
System.out.println(sortedMap);
//Compare
System.out.println(valueComparator.compare(1, 3));
System.out.println(valueComparator.compare(3, 1));
System.out.println(valueComparator.compare(1, 1));
System.out.println(valueComparator.compare(sortedMap.get("a"), sortedMap.get("a")));
System.out.println(valueComparator.compare(sortedMap.get("a"), sortedMap.get("b")));
System.out.println(valueComparator.compare(sortedMap.get("b"), sortedMap.get("a")));
Comparator comp = sortedMap.comparator();
System.out.println(comp);
}
}