How to Sort a Map by Values in C++ - Step by Step Examples



How to Sort a Map by Values in C++ ?

Answer

To sort a map by values in C++, you need to convert the map to a vector of pairs, sort the vector by values, and then optionally create a new map from the sorted vector. This method allows you to sort the map based on values.



✐ Examples

1 Sorting a Map by Values Using a Vector of Pairs

We can sort a map by values in C++ by converting the map to a vector of pairs, sorting the vector by values, and then optionally creating a new map from the sorted vector.

For example,

  1. We start by including the <map>, <vector>, <algorithm>, and <iostream> headers, which provide the necessary functions and data structures for working with maps, vectors, sorting, and input-output operations.
  2. We declare and initialize a map named myMap with some key-value pairs. In this example, the map has string keys and integer values.
  3. We create a vector of pairs named mapVector and copy the key-value pairs from the map to the vector.
  4. We sort the vector by values using the std::sort function with a custom comparator.
  5. We print the sorted vector to the console using a range-based for loop and the std::cout function to verify the sorting.
  6. Optionally, we create a new map from the sorted vector if needed.

C++ Program

#include <map>
#include <vector>
#include <algorithm>
#include <iostream>

int main() {
    // Declare and initialize a map
    std::map<std::string, int> myMap = {
        {"apple", 3},
        {"banana", 1},
        {"cherry", 2}
    };

    // Create a vector of pairs and copy the key-value pairs from the map to the vector
    std::vector<std::pair<std::string, int>> mapVector(myMap.begin(), myMap.end());

    // Sort the vector by values
    std::sort(mapVector.begin(), mapVector.end(),
        [](const std::pair<std::string, int>& a, const std::pair<std::string, int>& b) {
            return a.second < b.second;
        });

    // Print the sorted vector
    std::cout << "Sorted Map by Values:\n";
    for (const auto& pair : mapVector) {
        std::cout << pair.first << ": " << pair.second << std::endl;
    }

    // Optionally, create a new map from the sorted vector
    std::map<std::string, int> sortedMap;
    for (const auto& pair : mapVector) {
        sortedMap[pair.first] = pair.second;
    }

    return 0;
}

Output

Sorted Map by Values:
banana: 1
cherry: 2
apple: 3

2 Sorting a Map by Values in Descending Order

We can sort a map by values in descending order in C++ by converting the map to a vector of pairs, sorting the vector by values in descending order, and then optionally creating a new map from the sorted vector.

For example,

  1. We start by including the <map>, <vector>, <algorithm>, and <iostream> headers, which provide the necessary functions and data structures for working with maps, vectors, sorting, and input-output operations.
  2. We declare and initialize a map named myMap with some key-value pairs. In this example, the map has string keys and integer values.
  3. We create a vector of pairs named mapVector and copy the key-value pairs from the map to the vector.
  4. We sort the vector by values in descending order using the std::sort function with a custom comparator.
  5. We print the sorted vector to the console using a range-based for loop and the std::cout function to verify the sorting.
  6. Optionally, we create a new map from the sorted vector if needed.

C++ Program

#include <map>
#include <vector>
#include <algorithm>
#include <iostream>

int main() {
    // Declare and initialize a map
    std::map<std::string, int> myMap = {
        {"apple", 3},
        {"banana", 1},
        {"cherry", 2}
    };

    // Create a vector of pairs and copy the key-value pairs from the map to the vector
    std::vector<std::pair<std::string, int>> mapVector(myMap.begin(), myMap.end());

    // Sort the vector by values in descending order
    std::sort(mapVector.begin(), mapVector.end(),
        [](const std::pair<std::string, int>& a, const std::pair<std::string, int>& b) {
            return a.second > b.second;
        });

    // Print the sorted vector
    std::cout << "Sorted Map by Values (Descending):\n";
    for (const auto& pair : mapVector) {
        std::cout << pair.first << ": " << pair.second << std::endl;
    }

    // Optionally, create a new map from the sorted vector
    std::map<std::string, int> sortedMap;
    for (const auto& pair : mapVector) {
        sortedMap[pair.first] = pair.second;
    }

    return 0;
}

Output

Sorted Map by Values (Descending):
apple: 3
cherry: 2
banana: 1

3 Sorting a Map by Values with Integer Keys

We can sort a map with integer keys by values in C++ by converting the map to a vector of pairs, sorting the vector by values, and then optionally creating a new map from the sorted vector.

For example,

  1. We start by including the <map>, <vector>, <algorithm>, and <iostream> headers, which provide the necessary functions and data structures for working with maps, vectors, sorting, and input-output operations.
  2. We declare and initialize a map named myMap with some key-value pairs. In this example, the map has integer keys and string values.
  3. We create a vector of pairs named mapVector and copy the key-value pairs from the map to the vector.
  4. We sort the vector by values using the std::sort function with a custom comparator.
  5. We print the sorted vector to the console using a range-based for loop and the std::cout function to verify the sorting.
  6. Optionally, we create a new map from the sorted vector if needed.

C++ Program

#include <map>
#include <vector>
#include <algorithm>
#include <iostream>

int main() {
    // Declare and initialize a map
    std::map<int, std::string> myMap = {
        {3, "three"},
        {1, "one"},
        {2, "two"}
    };

    // Create a vector of pairs and copy the key-value pairs from the map to the vector
    std::vector<std::pair<int, std::string>> mapVector(myMap.begin(), myMap.end());

    // Sort the vector by values
    std::sort(mapVector.begin(), mapVector.end(),
        [](const std::pair<int, std::string>& a, const std::pair<int, std::string>& b) {
            return a.second < b.second;
        });

    // Print the sorted vector
    std::cout << "Sorted Map by Values:\n";
    for (const auto& pair : mapVector) {
        std::cout << pair.first << ": " << pair.second << std::endl;
    }

    // Optionally, create a new map from the sorted vector
    std::map<int, std::string> sortedMap;
    for (const auto& pair : mapVector) {
        sortedMap[pair.first] = pair.second;
    }

    return 0;
}

Output

Sorted Map by Values:
1: one
2: two
3: three

Summary

In this tutorial, we learned How to Sort a Map by Values in C++ language with well detailed examples.




More C++ Maps Tutorials

  1. How to create an Empty Map in C++ ?
  2. How to create a Map with Initial Key-Value Pairs in C++ ?
  3. How to Print a Map in C++ ?
  4. How to Add a Key-Value Pair to a Map in C++ ?
  5. How to Set a Default Value for a Key in a Map in C++ ?
  6. How to Update the Value for a Key in a Map in C++ ?
  7. How to Check if a Map is Empty in C++ ?
  8. How to Check if a Key Exists in a Map in C++ ?
  9. How to Check if a Value Exists in a Map in C++ ?
  10. How to Get the Value Associated with a Key in a Map in C++ ?
  11. How to Remove a Key-Value Pair from a Map in C++ ?
  12. How to Remove Key-Value Pairs from a Map Based on Values in C++ ?
  13. How to Clear All Key-Value Pairs from a Map in C++ ?
  14. How to Iterate Over Keys in a Map in C++ ?
  15. How to Iterate Over Values in a Map in C++ ?
  16. How to Iterate Over Entries (Key-Value Pairs) in a Map in C++ ?
  17. How to Get the Size (Number of Key-Value Pairs) of a Map in C++ ?
  18. How to Convert a Map to an Array of Keys in C++ ?
  19. How to Convert a Map to an Array of Values in C++ ?
  20. How to Convert a Map to an Array of Key-Value Pairs in C++ ?
  21. How to Merge Two Maps in C++ ?
  22. How to Copy a Map in C++ ?
  23. How to Check if Two Maps are Equal in C++ ?
  24. How to Sort a Map by Keys in C++ ?
  25. How to Sort a Map by Values in C++ ?
  26. How to Filter a Map Based on Keys in C++ ?
  27. How to Filter a Map Based on Values in C++ ?
  28. How to Reduce Values in a Map to a Single Value in C++ ?
  29. How to Convert an Array of Key-Value Pairs to a Map in C++ ?
  30. How to Convert a Map to a JSON String in C++ ?
  31. How to Convert a JSON String to a Map in C++ ?
  32. How to Swap Keys and Values in a Map in C++ ?
  33. How to Create a Map of Maps in C++ ?
  34. How to Iterate Over a Map of Maps in C++ ?