C ++ map max_size()函數用于獲取map容器可以容納的最大大小。
成員類型size_type是無符號整數類型。
size_type max_size() const; // 在 C++ 11 之前 size_type max_size() const noexcept; //從 C++ 11 開始
沒有
它返回map容器的最大允許長度。
讓我們看一個簡單的示例來計算map的最大容量。
#include <iostream>
#include <map>
using namespace std;
int main()
{
map<char,char> s;
cout << "map的最大大小是 " << s.max_size() << "\n";
}輸出:
map的最大大小是 268435455
在上面的示例中,max_size()函數返回map的最大容量。
讓我們看一個簡單的實例。
#include <iostream>
#include <map>
using namespace std;
int main ()
{
int i;
map<int,int> mymap;
if (mymap.max_size()>1000)
{
for (i=0; i<1000; i++) mymap[i]=0;
cout << "該map包含1000個元素。\n";
}
else cout << "map不能容納1000個元素。\n";
return 0;
}輸出:
該map包含1000個元素。
在上面的示例中,成員max_size用于預先檢查該map是否允許插入1000個元素。
讓我們看一個簡單的示例,查找一個空map和一個非空map的最大大小。
#include <map>
#include <iostream>
using namespace std;
int main()
{
//初始化容器
map<int, int> mp1, mp2;
mp1[1] = 1111;
//非空map的最大大小
cout << "mp1的最大大小為 " << mp1.max_size();
// 空map的最大大小
cout << "\nmp2的最大大小為 " << mp2.max_size();
return 0;
}輸出:
mp1的最大大小為 178956970 mp2的最大大小為 178956970
在上面的示例中,有兩個map,即m1和m2。m1是一個非空map,m2是一個空map。但是,兩個map的最大大小是相同的。
讓我們看一個簡單的實例。
#include <iostream>
#include <map>
#include <string>
using namespace std;
int main() {
typedef map<string, int> city;
string name;
int age;
city fmly ;
int n;
cout<<"輸入家庭成員人數 :";
cin>>n;
cout<<"輸入每個成員的姓名和年齡: \n";
for(int i =0; i<n; i++)
{
cin>> name;
cin>> age;
fmly[name] = age;
}
cout<<"\n城市總人口map: "<<fmly.max_size();
cout<<"\n家庭總成員是:"<< fmly.size();
cout<<"\n家庭成員的詳細信息: \n";
cout<<"\nName | Age \n ________________________\n";
city::iterator p;
for(p = fmly.begin(); p!=fmly.end(); p++)
{
cout<<(*p).first << " | " <<(*p).second <<" \n ";
}
return 0;
}輸出:
輸入家庭成員人數 : 3 輸入每個成員的姓名和年齡: Ram 42 Sita 37 Laxman 40 城市總人口map: 384307168202282325 家庭總成員是:3 家庭成員的詳細信息: Name | Age __________________________ Laxman | 40 Ram | 42 Sita | 37
在上面的示例中,程序首先以給定的大小交互創(chuàng)建城市map。然后,它顯示城市map可以包含的總大小,每張照片的總大小以及map中所有可用的名稱和年齡。