Why is the worst case complexity of std::unordered_multiset insert is linear? I understand why is that the case for std::unordered_set (you have to check that inserted value is not in the set) but for multiset I don't get it. Am I missing something obvious?
Complexity of std::unordered_multiset insert
1.8k views Asked by JamesJohnson At
1
There are 1 answers
Related Questions in C++
- How to immediately apply DISPLAYCONFIG_SCALING display scaling mode with SetDisplayConfig and DISPLAYCONFIG_PATH_TARGET_INFO
- Why can't I use templates members in its specialization?
- How to fix "Access violation executing location" when using GLFW and GLAD
- Dynamic array of structures in C++/ cannot fill a dynamic array of doubles in structure from dynamic array of structures
- How do I apply the interface concept with the base-class in design?
- File refuses to compile std::erase() even if using -std=g++23
- How can I do a successful map when the number of elements to be mapped is not consistent in Thrust C++
- Can std::bit_cast be applied to an empty object?
- Unexpected inter-thread happens-before relationships from relaxed memory ordering
- How i can move element of dynamic vector in argument of function push_back for dynamic vector
- Brick Breaker Ball Bounce
- Thread-safe lock-free min where both operands can change c++
- Watchdog Timer Reset on ESP32 using Webservers
- How to solve compiler error: no matching function for call to 'dmhFS::dmhFS()' in my case?
- Conda CMAKE CXX Compiler error while compiling Pytorch
Related Questions in C++11
- lvalue and rvalue references
- c++ range-for loop over custom class ::begin() expects 1 argument, 0 provided
- Difference between INT_MIN , INT8_MIN , INT16_MIN. For MAX too
- I am getting segmentation failt while assigning the resourcemanager instance
- Prevent reordering of prefetch instruction in c++
- How to Use libcurl to Check HTTP/S Proxy?
- Why we use `class` when there's `struct` in C++?
- Memory Management in C++: Differences in allocating shared_ptr using new vs make_shared
- Does C++ range-based `for` make copies?
- Is the behaviour is determined when initliasing the inner class's static member variable's value equal to the outer class's static member variable?
- Question about initialization. The output must be zeros with C++11 and afterwards?
- How to replace non-standard "for each" received from Visual C++ users
- G ++ can not pass the parameters in using the C ++ 11 process library under Windows?
- Why the Variadic Constructor with std::is_constructible Fails to Handle Initializer List Initialization?
- Class Object Error 'Undefined Reference For'
Related Questions in STL
- Why my code is working on everything except one instance?
- Why does the map size change?
- C++ ordered map optimized with index access
- Circular extention to std::array
- Is there a chance to use a custom std::pmr::polymorphic_allocator to make std::unordered_map’s buckets implemented as arrays?
- STL: Keeping Only Unique String Characters AND Preserving Order
- Importing <filesystem> in gcc
- Are there any iterator invalidation rules for <algorithms> operations?
- Check if Array Is Sorted and Rotated on LeetCode
- std::shared_mutex::unlock_shared() blocks even though there are no active exclusive locks on Windows
- could the type of std::map's key be double or float?
- How to implement an iterator for a two leveled map in C++?
- Why does priority_queue use greater<> for ascending order?
- Scope of C++ references and STL containers
- Implement Non Copyable Non Moveable wrapper for map/vector etc
Related Questions in TIME-COMPLEXITY
- C++ : Is there an objective universal way to compare the speed of iterative algorithms?
- Simplify complexity
- How to find big o of dependent loops and recursive functions?
- find number of unique durations given a list of durations and an upper bound
- What is the time complexity of doing two binary searches on an array?
- How to determine the time complexity of a recursive function that has a loop enclosed in it?
- Why is time complexity of Generate Parentheses O(4^n ( sqr root( n)))
- Find median in constant time O(1)
- Best Index - HackerEarth Solution, help me optimize the code
- Time complexity of Insertion Sort of an array of n numbers, with additional information
- How come checking for printable bytes is faster with the "in" operator rather than interval comparisons?
- Generate cuboids with integer sides and diagonals: how to improve the time complexity?
- What is the time complexity of this algorithm with two arrays?
- calculating number of operations in algorithm
- Time complexity of Rectangle Covering algorithm
Related Questions in UNORDERED-MULTISET
- Iterator invalidation with unordered_set/unordered_multiset
- Why does the == operator of std::unordered_multiset<T> returns wrong result when T is a pointer type?
- std::unordered_multiset exception iterating bucket
- std::distance goes wrong for unordered map
- I need to create a multiset on Java
- C++ vector of strings into associative vector of ints
- Why multiset keeps separate instances of repeated elements instead of their count?
- what is wrong with this code ? it's not showing any output after executing
- how to end a loop at a particular time in unordered_multiset
- Use of multisets in C++
- Number of distinct elements of std::unordered_multiset
- Generating Subsets of a Multiset in Ascending Order of the Sums of the Elements of the Subset
- Remove only one item from unordered_multiset
- Python inventory of objects
- How to reduce the memory consumption of unordered_multiset?
Popular Questions
- How do I undo the most recent local commits in Git?
- How can I remove a specific item from an array in JavaScript?
- How do I delete a Git branch locally and remotely?
- Find all files containing a specific text (string) on Linux?
- How do I revert a Git repository to a previous commit?
- How do I create an HTML button that acts like a link?
- How do I check out a remote Git branch?
- How do I force "git pull" to overwrite local files?
- How do I list all files of a directory?
- How to check whether a string contains a substring in JavaScript?
- How do I redirect to another webpage?
- How can I iterate over rows in a Pandas DataFrame?
- How do I convert a String to an int in Java?
- Does Python have a string 'contains' substring method?
- How do I check if a string contains a specific word?
Popular Tags
Trending Questions
- UIImageView Frame Doesn't Reflect Constraints
- Is it possible to use adb commands to click on a view by finding its ID?
- How to create a new web character symbol recognizable by html/javascript?
- Why isn't my CSS3 animation smooth in Google Chrome (but very smooth on other browsers)?
- Heap Gives Page Fault
- Connect ffmpeg to Visual Studio 2008
- Both Object- and ValueAnimator jumps when Duration is set above API LvL 24
- How to avoid default initialization of objects in std::vector?
- second argument of the command line arguments in a format other than char** argv or char* argv[]
- How to improve efficiency of algorithm which generates next lexicographic permutation?
- Navigating to the another actvity app getting crash in android
- How to read the particular message format in android and store in sqlite database?
- Resetting inventory status after order is cancelled
- Efficiently compute powers of X in SSE/AVX
- Insert into an external database using ajax and php : POST 500 (Internal Server Error)
The worst case complexity for
std::unordered_multiset::insert()is linear because:For example, consider the case where
5,13, and13are inserted into anunordered_multisetthat has4buckets, andunordered_multiset::key_eq(5, 13)returnsfalse. In this case,unordered_multiset::hash_function(5)returns different hash codes for both5and13. Despite having different hash codes, these elements may still be inserted into the same bucket. If the hash function for an integer returns the integer itself, and the bucket index is the result of the hash code modulus the number of buckets, then:5is hashed to5, and with4buckets, it is placed in bucket1.13is hashed to13, and with4buckets, it is placed into bucket1as well.While
unordered_set::insert()checks to prevent duplicates during insertion,unordered_multiset::insert()identifies where to insert the element for equivalent-key grouping. In the worst case, the bucket contains[5, 13]when inserting the final13, and upon iterating over all elements, the bucket contains[5, 13, 13]. As iteration over all elements occurs, the complexity is linear insize().It is worth noting that a rehash may occur during
unordered_multiset::insert(), andunordered_multiset::rehash()is specified as having a complexity with an average case linear insize()and the worst case is quadratic. During a rehash, all elements in the original hash table are iterated over and inserted into a new hash table. As iteration has a complexity linear insize(), and as identified above, each insertion has a worse case linear insize(), the resulting worst case isO(size()*size()).