How to Iterate Over Keys in a Map in C++ - Step by Step Examples



How to Iterate Over Keys in a Map in C++ ?

Answer

To iterate over keys in a map in C++, you can use a range-based for loop or an iterator. This allows you to access each key in the map.



✐ Examples

1 Iterating Over Keys Using Range-Based For Loop

We can iterate over keys in a map in C++ using a range-based for loop, which provides a convenient syntax for iterating over all keys in the map.

For example,

  1. We start by including the <map> and <iostream> header files, which provide the necessary functions and data structures for working with maps 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 use a range-based for loop to iterate over the keys of the map. We access each key using the first member of the map's key-value pairs.
  4. We print each key to the console using the std::cout function to verify that we are iterating over all keys.

C++ Program

#include <map>
#include <iostream>

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

    // Iterate over keys using range-based for loop
    for (const auto& pair : myMap) {
        std::cout << pair.first << std::endl;
    }

    return 0;
}

Output

1
2
3

2 Iterating Over Keys Using Iterator

We can iterate over keys in a map in C++ using an iterator, which provides a flexible way to access each key in the map.

For example,

  1. We start by including the <map> and <iostream> header files, which provide the necessary functions and data structures for working with maps 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 declare an iterator for the map using the std::map<int, std::string>::iterator type.
  4. We use a for loop to iterate over the keys of the map by incrementing the iterator. We access each key using the first member of the iterator's key-value pairs.
  5. We print each key to the console using the std::cout function to verify that we are iterating over all keys.

C++ Program

#include <map>
#include <iostream>

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

    // Declare an iterator for the map
    std::map<int, std::string>::iterator it;

    // Iterate over keys using iterator
    for (it = myMap.begin(); it != myMap.end(); ++it) {
        std::cout << it->first << std::endl;
    }

    return 0;
}

Output

1
2
3

3 Iterating Over Keys Using Key Extraction

We can extract and iterate over keys in a map in C++ by first storing the keys in a separate container.

For example,

  1. We start by including the <map>, <vector>, and <iostream> header files, which provide the necessary functions and data structures for working with maps, vectors, 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 declare a vector named keys to store the keys from the map.
  4. We use a range-based for loop to iterate over the keys of the map, and we store each key in the keys vector.
  5. We use another range-based for loop to iterate over the keys vector and print each key to the console using the std::cout function to verify that we are iterating over all keys.

C++ Program

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

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

    // Declare a vector to store the keys
    std::vector<int> keys;

    // Extract keys from the map
    for (const auto& pair : myMap) {
        keys.push_back(pair.first);
    }

    // Iterate over the keys vector
    for (const auto& key : keys) {
        std::cout << key << std::endl;
    }

    return 0;
}

Output

1
2
3

Summary

In this tutorial, we learned How to Iterate Over Keys in a Map 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++ ?