Notice: This page requires JavaScript to function properly.
Please enable JavaScript in your browser settings or update your browser.
Apprendre Unordered Containers: unordered_set, unordered_map | Containers
C++ STL Containers and Algorithms

bookUnordered Containers: unordered_set, unordered_map

Note
Definition

Unordered containers in C++ store and retrieve elements using hash tables, offering average constant-time performance for insertions and lookups.

Unlike ordered containers like std::set and std::map, unordered containers such as std::unordered_set and std::unordered_map do not keep elements sorted. Instead, they rely on hashing, where a key’s hash value determines its storage bucket, enabling faster access in most cases.

The most commonly used unordered containers are std::unordered_set and std::unordered_map:

  • Offer fast, average-case constant time insertions and lookups;
  • Do not maintain any particular order of elements;
  • May degrade to linear time in the worst case due to hash collisions;
  • Are ideal when you prioritize speed for key-based operations over element ordering.

Choosing between ordered and unordered containers depends on whether you prioritize element ordering or average-case speed for key-based operations.

main.cpp

main.cpp

copy
123456789101112131415161718
#include <iostream> #include <unordered_map> #include <string> int main() { std::unordered_map<std::string, int> wordCounts; wordCounts["apple"] = 3; wordCounts["banana"] = 5; wordCounts["orange"] = 2; std::string query = "banana"; if (wordCounts.find(query) != wordCounts.end()) std::cout << query << ": " << wordCounts[query] << '\n'; else std::cout << query << " not found.\n"; }

Unordered containers use hash functions to distribute elements efficiently across internal buckets. C++ provides built-in hash functions for standard types, but for custom types, you may need to define your own to ensure even distribution and minimize collisions.

Collisions occur when different keys produce the same hash value. The container handles them by grouping elements in the same bucket, often using linked lists. To maintain constant-time performance, use a well-designed hash function and provide both a custom hash and an equality function when working with user-defined key types.

main.cpp

main.cpp

copy
123456789101112131415161718192021
#include <iostream> #include <unordered_set> struct Point { int x, y; bool operator==(const Point& other) const { return x == other.x && y == other.y; } }; struct PointHash { std::size_t operator()(const Point& p) const { return std::hash<int>()(p.x) ^ (std::hash<int>()(p.y) << 1); } }; int main() { std::unordered_set<Point, PointHash> points; points.insert({1, 2}); points.insert({3, 4}); points.insert({1, 2}); // Duplicate, will not be inserted std::cout << "Number of unique points: " << points.size() << '\n'; }
question mark

Which statement best describes unordered containers like std::unordered_set and std::unordered_map in C++?

Select the correct answer

Tout était clair ?

Comment pouvons-nous l'améliorer ?

Merci pour vos commentaires !

Section 2. Chapitre 4

Demandez à l'IA

expand

Demandez à l'IA

ChatGPT

Posez n'importe quelle question ou essayez l'une des questions suggérées pour commencer notre discussion

Awesome!

Completion rate improved to 6.67

bookUnordered Containers: unordered_set, unordered_map

Glissez pour afficher le menu

Note
Definition

Unordered containers in C++ store and retrieve elements using hash tables, offering average constant-time performance for insertions and lookups.

Unlike ordered containers like std::set and std::map, unordered containers such as std::unordered_set and std::unordered_map do not keep elements sorted. Instead, they rely on hashing, where a key’s hash value determines its storage bucket, enabling faster access in most cases.

The most commonly used unordered containers are std::unordered_set and std::unordered_map:

  • Offer fast, average-case constant time insertions and lookups;
  • Do not maintain any particular order of elements;
  • May degrade to linear time in the worst case due to hash collisions;
  • Are ideal when you prioritize speed for key-based operations over element ordering.

Choosing between ordered and unordered containers depends on whether you prioritize element ordering or average-case speed for key-based operations.

main.cpp

main.cpp

copy
123456789101112131415161718
#include <iostream> #include <unordered_map> #include <string> int main() { std::unordered_map<std::string, int> wordCounts; wordCounts["apple"] = 3; wordCounts["banana"] = 5; wordCounts["orange"] = 2; std::string query = "banana"; if (wordCounts.find(query) != wordCounts.end()) std::cout << query << ": " << wordCounts[query] << '\n'; else std::cout << query << " not found.\n"; }

Unordered containers use hash functions to distribute elements efficiently across internal buckets. C++ provides built-in hash functions for standard types, but for custom types, you may need to define your own to ensure even distribution and minimize collisions.

Collisions occur when different keys produce the same hash value. The container handles them by grouping elements in the same bucket, often using linked lists. To maintain constant-time performance, use a well-designed hash function and provide both a custom hash and an equality function when working with user-defined key types.

main.cpp

main.cpp

copy
123456789101112131415161718192021
#include <iostream> #include <unordered_set> struct Point { int x, y; bool operator==(const Point& other) const { return x == other.x && y == other.y; } }; struct PointHash { std::size_t operator()(const Point& p) const { return std::hash<int>()(p.x) ^ (std::hash<int>()(p.y) << 1); } }; int main() { std::unordered_set<Point, PointHash> points; points.insert({1, 2}); points.insert({3, 4}); points.insert({1, 2}); // Duplicate, will not be inserted std::cout << "Number of unique points: " << points.size() << '\n'; }
question mark

Which statement best describes unordered containers like std::unordered_set and std::unordered_map in C++?

Select the correct answer

Tout était clair ?

Comment pouvons-nous l'améliorer ?

Merci pour vos commentaires !

Section 2. Chapitre 4
some-alt