C ++ max_size()函數(shù)用于獲取設(shè)置的容器可以容納的最大大小數(shù)。
成員類型size_type是無符號整數(shù)類型。
size_type max_size() const; // C++ 11 之前 size_type max_size() const noexcept; //從 C++ 11開始
沒有
它返回設(shè)置的容器的最大允許長度。
不變。
沒有變化。
容器被訪問。
同時訪問集合的元素是安全的。
該成員函數(shù)永遠不會引發(fā)異常。
讓我們看一個簡單的示例來計算集合的最大大小:
#include <iostream>
#include <set>
using namespace std;
int main()
{
set<char,char> s;
cout << "“set集合”的最大大小為" << s.max_size() << "\n";
return 0;
}輸出:
“set集合”的最大大小為268435455
在上面的示例中,max_size()函數(shù)返回集合的最大大小。
讓我們看一個簡單的實例:
#include <iostream>
#include <set>
using namespace std;
int main ()
{
int i;
set<int> myset;
if (myset.max_size()>1000)
{
for (i=0; i<1000; i++) myset.insert(0);
cout << "該集合包含1000個元素。\n";
}
else cout << "該集合不能容納1000個元素。\n";
return 0;
}輸出:
該集合包含1000個元素。
在上面的示例中,成員max_size用于預(yù)先檢查該集合是否允許插入1000個元素。
讓我們看一個簡單的示例,查找一個空集和一個非空集的最大大?。?/p>
#include <set>
#include <iostream>
using namespace std;
int main()
{
// 初始化容器
set<int> mp1, mp2;
mp1 = {1111};
// 非空集的最大大小
cout << "mp1的最大大小為 " << mp1.max_size();
// 最大空集大小
cout << "\nmp2的最大大小為 " << mp2.max_size();
return 0;
}輸出:
mp1的最大大小為 214748364 mp2的最大大小為 214748364
在上面的示例中,有兩組集合,即mp1和mp2。mp1是一個非空集,mp2是一個空集。但是兩組的最大大小是相同的。
讓我們看一個簡單的實例:
#include <iostream>
#include <set>
#include <string>
using namespace std;
int main() {
typedef set<string> city;
string name;
city fmly ;
int n;
cout<<"輸入家庭成員的數(shù)量 :";
cin>>n;
cout<<"輸入每個成員的姓名: \n";
for(int i =0; i<n; i++)
{
cin>> name;
fmly.insert(name); // 將姓名插入集合
}
cout<<"\n城市總?cè)丝跀?shù)集: "<<fmly.max_size();
cout<<"\n家庭的總成員是:"<< fmly.size();
cout<<"\n家庭成員姓名: \n";
cout<<"\n姓名 \n ________________________\n";
city::iterator p;
for(p = fmly.begin(); p!=fmly.end(); p++)
{
cout<<(*p)<<" \n ";
}
return 0;
}輸出:
輸入家庭成員的數(shù)量 :5 輸入每個成員的姓名: 張三 張思 李四 王五 李麻子 城市總?cè)丝跀?shù)集: 97612893 家庭的總成員是:5 家庭成員姓名: 姓名 ________________________ 李麻子 李四 王五 張三 張思
在上面的示例中,程序首先以給定的大小交互創(chuàng)建城市集。然后,它會顯示一個城市組可以包含的總大小,一個小城市的總大小以及該組中可用的所有名稱及其年齡。