Logo

Programming-Idioms

  • Obj-C
  • Python

Idiom #112 Iterate over map entries, ordered by keys

Print each key k with its value x from an associative array mymap, in ascending order of k.

print(*sorted(mymap.items()))
for k, x in sorted(mymap.items()):
    print(k, x)
for k in sorted(mymap):
    print(mymap[k])

dictionaries iterate over their keys by default
#include <iostream>
#include <map>
std::map< K, V > _mymap;
for (const auto& pair : _mymap) {
    std::cout << pair.first << ": " << pair.second << "\n";
}

std::map is a sorted collection that uses std::less by default.

New implementation...