unordered_multimap::reserve()是C++ STL中的內置函數,該函數將容器中的存儲桶數(bucket_count)設置為最合適的數字,以使其至少包含n個元素。如果n大於當前的bucket_count乘以max_load_factor,則該容器的bucket_count會增加,並強製進行重新哈希處理。通過使用unordered_multimap容器預期的大小調用reserve,可以避免多次重複。多次重複是由於容器大小增加而產生的,從而優化了哈希表的大小。如果n小於該值,則該函數可能無效。
用法:
unordered_multimap_name.reserve(N)
參數:該函數接受單個強製性參數N,該參數將請求的元素數指定為最小容量。
返回值:該函數不返回任何內容。
以下示例程序旨在說明上述函數:
示例1:
// C++ program to illustrate the
// unordered_multimap::reserve()
#include <bits/stdc++.h>
using namespace std;
int main()
{
// declaration
unordered_multimap<int, int> sample1, sample2;
// the sample1 size is reserved for
// the bucket to contain a minimum of
// one elements
sample1.reserve(1);
// inserts key and element
// in sample1
sample1.insert({ 10, 100 });
sample1.insert({ 50, 500 });
// inserts key and element
// in sample1
// the sample1 size is reserved for
// the bucket to contain a minimum of
// three elements
sample2.reserve(3);
sample2.insert({ 20, 200 });
sample2.insert({ 30, 300 });
sample2.insert({ 30, 150 });
cout << "The size of Sample1 is: " << sample1.size();
cout << "\nKey and Elements of Sample1 are:";
for (auto it = sample1.begin(); it != sample1.end(); it++) {
cout << "{" << it->first << ", " << it->second << "} ";
}
cout << "\n\nThe size of Sample2 is: " << sample2.size();
cout << "\nKey and Elements of Sample2 are:";
for (auto it = sample2.begin(); it != sample2.end(); it++) {
cout << "{" << it->first << ", " << it->second << "} ";
}
return 0;
}
輸出:
The size of Sample1 is: 2 Key and Elements of Sample1 are:{50, 500} {10, 100} The size of Sample2 is: 3 Key and Elements of Sample2 are:{30, 150} {30, 300} {20, 200}
示例2:
// C++ program to illustrate the
// unordered_multimap::reserve()
#include <bits/stdc++.h>
using namespace std;
int main()
{
// declaration
unordered_multimap<char, char> sample1, sample2;
// the sample1 size is reserved for
// the bucket to contain a minimum of
// one elements
sample1.reserve(1);
// inserts key and element
// in sample1
sample1.insert({ 'a', 'A' });
sample1.insert({ 'g', 'G' });
// inserts key and element
// in sample1
// the sample1 size is reserved for
// the bucket to contain a minimum of
// three elements
sample2.reserve(3);
sample2.insert({ 'b', 'B' });
sample2.insert({ 'c', 'C' });
sample2.insert({ 'd', 'D' });
cout << "The size of Sample1 is: " << sample1.size();
cout << "\nKey and Elements of Sample1 are:";
for (auto it = sample1.begin(); it != sample1.end(); it++) {
cout << "{" << it->first << ", " << it->second << "} ";
}
cout << "\n\nThe size of Sample2 is: " << sample2.size();
cout << "\nKey and Elements of Sample2 are:";
for (auto it = sample2.begin(); it != sample2.end(); it++) {
cout << "{" << it->first << ", " << it->second << "} ";
}
return 0;
}
輸出:
The size of Sample1 is: 2 Key and Elements of Sample1 are:{g, G} {a, A} The size of Sample2 is: 3 Key and Elements of Sample2 are:{d, D} {c, C} {b, B}
相關用法
- C++ unordered_set reserve()用法及代碼示例
- C++ unordered_map reserve()用法及代碼示例
- C++ unordered_multiset reserve()用法及代碼示例
- C++ div()用法及代碼示例
- C++ fma()用法及代碼示例
- C++ log()用法及代碼示例
- C++ map key_comp()用法及代碼示例
- C++ map rbegin()用法及代碼示例
注:本文由純淨天空篩選整理自gopaldave大神的英文原創作品 unordered_multimap reserve() function in C++ STL。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。