How to Sort a Map by Keys in Java - Step by Step Examples
How to Sort a Map by Keys in Java ?
Answer
To sort a map by keys in Java, you can use a `TreeMap`, which automatically sorts the keys, or convert the map entries to a list, sort the list, and then convert it back to a map. This method provides a way to ensure the map is sorted by keys.
✐ Examples
1 Sorting a Map by Keys Using TreeMap
We can sort a map by keys in Java by using a `TreeMap`, which automatically sorts the keys.
For example,
- We start by importing the
java.util.HashMap
andjava.util.TreeMap
classes, which provide the necessary functions and data structures for working with maps. - We declare and initialize a `HashMap` named
unsortedMap
with some key-value pairs. In this example, the map has integer keys and string values. - We create a `TreeMap` named
sortedMap
and pass the `unsortedMap` to it, which automatically sorts the keys. - We print the sorted map to the console using the `System.out.println` function to verify the sorting.
Java Program
import java.util.HashMap;
import java.util.Map;
import java.util.TreeMap;
public class Main {
public static void main(String[] args) {
// Declare and initialize an unsorted map
Map<Integer, String> unsortedMap = new HashMap<>();
unsortedMap.put(3, "three");
unsortedMap.put(1, "one");
unsortedMap.put(2, "two");
// Create a TreeMap to sort the keys
Map<Integer, String> sortedMap = new TreeMap<>(unsortedMap);
// Print the sorted map
System.out.println("Sorted Map by Keys: " + sortedMap);
}
}
Output
Sorted Map by Keys: {1=one, 2=two, 3=three}
2 Sorting a Map by Keys Using List Conversion
We can sort a map by keys in Java by converting the map entries to a list, sorting the list, and then converting it back to a map.
For example,
- We start by importing the
java.util.HashMap
,java.util.List
,java.util.Map
,java.util.stream.Collectors
, andjava.util.LinkedHashMap
classes, which provide the necessary functions and data structures for working with maps and lists. - We declare and initialize a `HashMap` named
unsortedMap
with some key-value pairs. In this example, the map has integer keys and string values. - We convert the map entries to a list and sort the list based on the keys using streams.
- We create a new `LinkedHashMap` from the sorted list of map entries.
- We print the sorted map to the console using the `System.out.println` function to verify the sorting.
Java Program
import java.util.HashMap;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.stream.Collectors;
public class Main {
public static void main(String[] args) {
// Declare and initialize an unsorted map
Map<Integer, String> unsortedMap = new HashMap<>();
unsortedMap.put(3, "three");
unsortedMap.put(1, "one");
unsortedMap.put(2, "two");
// Convert the map entries to a list and sort the list by keys
List<Map.Entry<Integer, String>> sortedEntries = unsortedMap.entrySet()
.stream()
.sorted(Map.Entry.comparingByKey())
.collect(Collectors.toList());
// Create a new map from the sorted list of map entries
Map<Integer, String> sortedMap = new LinkedHashMap<>();
for (Map.Entry<Integer, String> entry : sortedEntries) {
sortedMap.put(entry.getKey(), entry.getValue());
}
// Print the sorted map
System.out.println("Sorted Map by Keys: " + sortedMap);
}
}
Output
Sorted Map by Keys: {1=one, 2=two, 3=three}
3 Sorting a Map by Keys in Descending Order
We can sort a map by keys in descending order in Java by using a `TreeMap` with a custom comparator.
For example,
- We start by importing the
java.util.HashMap
,java.util.Map
, andjava.util.TreeMap
classes, which provide the necessary functions and data structures for working with maps and comparators. - We declare and initialize a `HashMap` named
unsortedMap
with some key-value pairs. In this example, the map has integer keys and string values. - We create a `TreeMap` named
sortedMap
with a custom comparator to sort the keys in descending order, and pass the `unsortedMap` to it. - We print the sorted map to the console using the `System.out.println` function to verify the sorting.
Java Program
import java.util.HashMap;
import java.util.Map;
import java.util.TreeMap;
import java.util.Comparator;
public class Main {
public static void main(String[] args) {
// Declare and initialize an unsorted map
Map<Integer, String> unsortedMap = new HashMap<>();
unsortedMap.put(3, "three");
unsortedMap.put(1, "one");
unsortedMap.put(2, "two");
// Create a TreeMap with a custom comparator for descending order
Map<Integer, String> sortedMap = new TreeMap<>(Comparator.reverseOrder());
sortedMap.putAll(unsortedMap);
// Print the sorted map
System.out.println("Sorted Map by Keys (Descending): " + sortedMap);
}
}
Output
Sorted Map by Keys (Descending): {3=three, 2=two, 1=one}
Summary
In this tutorial, we learned How to Sort a Map by Keys in Java language with well detailed examples.
More Java Maps Tutorials
- How to create an Empty Map in Java ?
- How to create a Map with Initial Key-Value Pairs in Java ?
- How to Print a Map in Java ?
- How to Add a Key-Value Pair to a Map in Java ?
- How to Set a Default Value for a Key in a Map in Java ?
- How to Update the Value for a Key in a Map in Java ?
- How to Check if a Map is Empty in Java ?
- How to Check if a Key Exists in a Map in Java ?
- How to Check if a Value Exists in a Map in Java ?
- How to Get the Value Associated with a Key in a Map in Java ?
- How to Remove a Key-Value Pair from a Map in Java ?
- How to Remove Key-Value Pairs from a Map Based on Values in Java ?
- How to Clear All Key-Value Pairs from a Map in Java ?
- How to Iterate Over Keys in a Map in Java ?
- How to Iterate Over Values in a Map in Java ?
- How to Iterate Over Entries (Key-Value Pairs) in a Map in Java ?
- How to Get the Size (Number of Key-Value Pairs) of a Map in Java ?
- How to Convert a Map to an Array of Keys in Java ?
- How to Convert a Map to an Array of Values in Java ?
- How to Merge Two Maps in Java ?
- How to Copy a Map in Java ?
- How to Check if Two Maps are Equal in Java ?
- How to Sort a Map by Keys in Java ?
- How to Sort a Map by Values in Java ?
- How to Filter a Map Based on Keys in Java ?
- How to Filter a Map Based on Values in Java ?
- How to Reduce Values in a Map to a Single Value in Java ?
- How to Convert an Array of Key-Value Pairs to a Map in Java ?
- How to Convert a Map to a JSON String in Java ?
- How to Convert a JSON String to a Map in Java ?
- How to Swap Keys and Values in a Map in Java ?
- How to Create a Map of Maps in Java ?
- How to Iterate Over a Map of Maps in Java ?