This example shows how to convert HashSet to TreeSet in Java. This example also shows how to convert HashSet to TreeSet using the constructor and addAll method.
How to convert HashSet to TreeSet in Java?
The HashSet and TreeSet classes are implementations of the Set interface. The HashSet is backed by an instance of the HashMap class, while the TreeSet is an implementation based on the TreeMap.
Since both the classes implement the Set interface, none of them allow duplicate elements. The HashSet class does not guarantee the order of its elements while TreeSet class sorts the elements according to their natural order or by the provided custom comparator.
There are a couple of ways using which we can convert HashSet object to the TreeSet object as given below.
1. Using TreeSet constructor
The TreeSet class provides a copy constructor that creates a new TreeSet object containing all the elements of the specified collection object.
1 |
public TreeSet(Collection<? extends E> collection) |
Since the HashSet class is a child class of the Collection interface, we can pass the HashSet object into this constructor.
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 |
import java.util.HashSet; import java.util.TreeSet; public class HashSetToTreeSetExample { public static void main(String[] args) { HashSet<Integer> hSetNumbers = new HashSet<Integer>(); hSetNumbers.add(23); hSetNumbers.add(34); hSetNumbers.add(45); hSetNumbers.add(12); hSetNumbers.add(42); System.out.println("HashSet contains: " + hSetNumbers); /* * To convert HashSet to TreeSet, use the * TreeSet constructor and pass the HashSet object */ TreeSet<Integer> tSetNumbers = new TreeSet<Integer>( hSetNumbers ); System.out.println("TreeSet contains: " + tSetNumbers); } } |
Output
1 2 |
HashSet contains: [34, 23, 42, 12, 45] TreeSet contains: [12, 23, 34, 42, 45] |
As we can see from the output, the TreeSet class has automatically sorted the elements in their natural order i.e. ascending order for the Integer type.
2. Using the addAll method of the TreeSet class
The addAll
method of the TreeSet class adds all the elements of the specified collection to this set object.
1 |
public boolean addAll(Collection<? extends E> collection) |
We will first create a new and empty TreeSet object and then use the addAll
method to add all elements of the HashSet object to the TreeSet object as given below.
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 |
import java.util.HashSet; import java.util.TreeSet; public class HashSetToTreeSetExample { public static void main(String[] args) { HashSet<Integer> hSetNumbers = new HashSet<Integer>(); hSetNumbers.add(23); hSetNumbers.add(34); hSetNumbers.add(45); hSetNumbers.add(12); hSetNumbers.add(42); System.out.println("HashSet contains: " + hSetNumbers); //create a new empty TreeSet TreeSet<Integer> tSetNumbers = new TreeSet<Integer>(); //add all elements of HashSet to TreeSet tSetNumbers.addAll(hSetNumbers); System.out.println("TreeSet contains: " + tSetNumbers); } } |
Output
1 2 |
HashSet contains: [34, 23, 42, 12, 45] TreeSet contains: [12, 23, 34, 42, 45] |
How to convert HashSet of the custom class objects to a TreeSet object?
Let’s have a look at the below example of HashSet of custom class elements.
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 |
import java.util.HashSet; import java.util.TreeSet; class Employee{ private int id; public Employee(int id){ this.id = id; } public int getId(){ return this.id; } public String toString(){ return "Employee -> " + getId(); } } public class HashSetToTreeSetExample { public static void main(String[] args) { HashSet<Employee> hSetEmployees = new HashSet<Employee>(); hSetEmployees.add( new Employee(3) ); hSetEmployees.add( new Employee(5) ); hSetEmployees.add( new Employee(4) ); hSetEmployees.add( new Employee(1) ); hSetEmployees.add( new Employee(2) ); System.out.println("HashSet contains: " + hSetEmployees); //convert HashSet to TreeSet TreeSet<Employee> tSetEmployees = new TreeSet<Employee>( hSetEmployees ); System.out.println("TreeSet contains: " + tSetEmployees); } } |
Output
1 2 3 4 5 6 7 8 |
HashSet contains: [Employee -> 4, Employee -> 2, Employee -> 3, Employee -> 5, Employee -> 1] Exception in thread "main" java.lang.ClassCastException: com.javacodeexamples.collections.treeset.Employee cannot be cast to java.lang.Comparable at java.util.TreeMap.compare(Unknown Source) at java.util.TreeMap.put(Unknown Source) at java.util.TreeSet.add(Unknown Source) at java.util.AbstractCollection.addAll(Unknown Source) at java.util.TreeSet.addAll(Unknown Source) at java.util.TreeSet.<init>(Unknown Source) |
The code throws the java.lang.ClassCastException exception because all elements of the TreeSet either must implement the Comparable interface or a custom Comparator must be provided in the TreeSet constructor. We did neither of that.
Let’s implement the Comparable interface in the Employee class and try again.
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 |
import java.util.HashSet; import java.util.TreeSet; /* * 1. Implement the Comparable interface */ class Employee implements Comparable<Employee>{ private int id; public Employee(int id){ this.id = id; } public int getId(){ return this.id; } public String toString(){ return "Employee -> " + getId(); } /* * 2. Define the compareTo method. * * This method will sort Employee objects * according to the id in ascending order */ public int compareTo(Employee otherEmployee) { return this.getId() - otherEmployee.getId(); } } public class HashSetToTreeSetExample { public static void main(String[] args) { HashSet<Employee> hSetEmployees = new HashSet<Employee>(); hSetEmployees.add( new Employee(3) ); hSetEmployees.add( new Employee(5) ); hSetEmployees.add( new Employee(4) ); hSetEmployees.add( new Employee(1) ); hSetEmployees.add( new Employee(2) ); System.out.println("HashSet contains: " + hSetEmployees); //convert HashSet to TreeSet TreeSet<Employee> tSetEmployees = new TreeSet<Employee>( hSetEmployees ); System.out.println("TreeSet contains: " + tSetEmployees); } } |
Output
1 2 |
HashSet contains: [Employee -> 4, Employee -> 2, Employee -> 3, Employee -> 5, Employee -> 1] TreeSet contains: [Employee -> 1, Employee -> 2, Employee -> 3, Employee -> 4, Employee -> 5] |
As we can see from the output, the Employee objects are now automatically sorted by the TreeSet in ascending order of the id field.
This example is a part of the TreeSet in Java Tutorial with Examples.
Please let me know your views in the comments section below.
References:
Java 8 TreeSet