编辑这个页面须要登录或更高权限!
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
在上面的示例中,程序首先以给定的大小交互创建城市map。然后,它显示城市map可以包含的总大小,每张照片的总大小以及map中所有可用的名称和年龄。