Załóżmy, że chciałbym zmapować dane z ciągiem znaków jako kluczem. Jaki pojemnik powinienem wybrać, mapczy unordered_map? unordered_mapzajmuje więcej pamięci, więc załóżmy, że pamięć nie jest problemem, a problemem jest szybkość.
unordered_mappowinien generalnie dawać średnią złożoność O (1) z najgorszym przypadkiem O (n). W jakich przypadkach doszłoby do O (n)? Kiedy można mapuzyskać większą oszczędność czasu niż unordered_map? Czy to się dzieje, gdy n jest małe?
Zakładając, że użyłbym STL unordered_mapz domyślnym haser Vs. mapa. ciąg jest kluczem.
Jeśli mam zamiar iterować elementy, zamiast uzyskiwać dostęp do pojedynczego elementu za każdym razem, czy wolę map?