 
 Data Structure Data Structure
 Networking Networking
 RDBMS RDBMS
 Operating System Operating System
 Java Java
 MS Excel MS Excel
 iOS iOS
 HTML HTML
 CSS CSS
 Android Android
 Python Python
 C Programming C Programming
 C++ C++
 C# C#
 MongoDB MongoDB
 MySQL MySQL
 Javascript Javascript
 PHP PHP
- Selected Reading
- UPSC IAS Exams Notes
- Developer's Best Practices
- Questions and Answers
- Effective Resume Writing
- HR Interview Questions
- Computer Glossary
- Who is Who
Java Program to Sort map by keys
In this article, we will learn to sort maps by keys in Java. In Java, the Map interface provides a collection of key-value pairs where each key is unique. Sorting a map by its keys can be useful when you want to order the elements based on the keys instead of their values.
Sorting a Map in Java
Java provides different ways to sort a map by keys. A TreeMap, a part of the java.util package is one of the easiest ways to sort a map. It stores the map entries in a natural order (ascending) based on the keys. If you need more control over the sorting order, you can use Collections.sort() with a custom comparator.
Example ?
input
Input map: {1=Scala, 2=Python, 3=Java}
Output
The sorted map with the key:
{1=Scala, 2=Python, 3=Java}
Different Approaches
Following are the different approaches of sorting a map by keys in Java ?
Using TreeMap
A TreeMap automatically sorts the map by keys in ascending order. When you create a TreeMap from an existing map, the entries will be sorted based on their keys.
Following are the steps to sort a map by keys using a TreeMap ?
- Step 1: We first create a HashMap and populate it with some key-value pairs using the put() method.
 
- Step 2: We create a TreeMap and pass the HashMap to it. The TreeMap sorts the entries based on the natural order of the keys.
 
- Step 3: Finally, we print both the original and sorted maps.
TreeMapresult_map = new TreeMap<>(input_map); 
Example
Below is an example of sorting a map by keys using a TreeMap ?
import java.util.HashMap;
import java.util.Map;
import java.util.TreeMap;
public class Demo {
   public static void main(String[] args) {
      Map<String, String> input_map = new HashMap<>();
      input_map.put("1", "Scala");
      input_map.put("3", "Java");
      input_map.put("2", "Python");
      System.out.println("The map is defined as: " + input_map);
      TreeMap<String, String> result_map = new TreeMap<>(input_map);
      System.out.println("\nThe sorted map with the key: \n" + result_map);
   }
}
Output
The map is defined as: {1=Scala, 2=Python, 3=Java}
The sorted map with the key:
{1=Scala, 2=Python, 3=Java}
Time Complexity: O(nlog?n), for sorting the entries based on keys, where n is the number of entries in the map.
Space Complexity: O(n), for storing the entries in the TreeMap.
Using Collections.sort()
Another way to sort a map is by using Collections.sort() on the map's entries. This allows you to customize the sorting using a comparator.
Following are the steps to sort a map by keys using Collections.sort() ?
- Step 1: Convert the map entries into a list using map.entrySet().
 
- Step 2: Sort the list of entries using Collections.sort() and the comparingByKey() comparator.
 
- Step 3: Create a new LinkedHashMap and put the sorted entries into it to maintain the order.
 
- Step 4: Print the sorted map.
 
Sorting the map's entries by key ?
List> list = new ArrayList<>(map.entrySet());
list.sort(Map.Entry.comparingByKey());
Example
Below is an example of sorting a map by keys using Collections.sort() ?
import java.util.*;
public class SortMapUsingCollections {
    public static void main(String[] args) {
        // Creating a Map
        Map<String, Integer> map = new HashMap<>();
        map.put("Java", 8);
        map.put("Python", 3);
        map.put("C++", 7);
        map.put("Ruby", 2);
        // Printing original map
        System.out.println("Original Map: " + map);
        // Sorting the map's entries by key
        List<Map.Entry<String, Integer>> list = new ArrayList<>(map.entrySet());
        list.sort(Map.Entry.comparingByKey());
        // Creating a new map with the sorted entries
        Map<String, Integer> sortedMap = new LinkedHashMap<>();
        for (Map.Entry<String, Integer> entry : list) {
            sortedMap.put(entry.getKey(), entry.getValue());
        }
        // Printing the sorted map
        System.out.println("Sorted Map by Keys: " + sortedMap);
    }
}
Output
Original Map: {Java=8, Python=3, C++=7, Ruby=2}
Sorted Map by Keys: {C++=7, Java=8, Python=3, Ruby=2}
Time Complexity: O(nlog?n), for sorting the entries using Collections.sort(), where n is the number of entries.
Space Complexity: O(n), for storing the list of entries and the sorted map.
Conclusion
In Java, sorting a map by keys can be done using different methods. Using TreeMap we can automatically sort the map entries in ascending order based on the natural order of the keys. This is a quick and efficient approach. While using the Collections.sort() it provides more flexibility to apply custom sorting using a comparator, although it requires additional steps to convert the map to a list and then back to a map.
