C ++ map size()函数用于查找map容器中存在的元素数。
成员类型size_type是无符号整数类型。
size_type size() const; // 在 C++ 11 之前 size_type size() const noexcept; //从 C++ 11 开始
没有
它返回map中存在的元素数。
让我们看一个简单的示例来计算map的大小。
#include <map>
#include <iostream>
using namespace std;
int main()
{
map<int,char> num {{1, 'a'}, {3, 'b'}, {5, 'c'}, {7, 'd'}};
cout << "map容器num包含 " << num.size() << " 个元素.\n";
}输出:
map容器num包含 4 个元素.
在上面的示例中,映射num包含4个元素。因此,size()函数返回4个元素。
让我们看一个简单的示例,计算map的初始大小和添加元素后的map大小。
#include <iostream>
#include <map>
using namespace std;
int main(void) {
map<char, int> m;
cout << "map的初始大小 = " << m.size() << endl;
m = {
{'a', 1},
{'b', 2},
{'c', 3},
{'d', 4},
{'e', 5},
};
cout << "Size of map after inserting elements = " << m.size() << endl;
return 0;
}输出:
map的初始大小 = 0 插入元素后的map大小 = 5
在上面的示例中,第一个map为空。因此,size()函数将返回0,在插入5个元素后将返回5。
让我们看一个简单的实例。
#include <iostream>
#include <map>
using namespace std;
int main ()
{
map<char,int> mymap;
mymap['x']=100;
mymap['y']=200;
mymap['z']=300;
while (mymap.size())
{
cout << mymap.begin()->first << " => " << mymap.begin()->second << '\n';
mymap.erase(mymap.begin());
}
return 0;
}输出:
x => 100 y => 200 z => 300
在上面的示例中,它仅在while循环中使用size()函数,并打印map的元素,直到map的大小为止。
让我们看一个简单的实例。
#include <iostream>
#include <map>
#include <string>
using namespace std;
int main() {
typedef map<string, int> phoneMap;
string name;
int number;
phoneMap phone;
cout<<"输入三组名称和数字: \n";
for(int i =0; i<3; i++)
{
cin>> name;
cin>> number;
phone[name] = number;
}
cout<<"\n电话map的大小是:"<< phone.size();
cout<<"\n电话号码列表: \n";
phoneMap::iterator p;
for(p = phone.begin(); p!=phone.end(); p++)
{
cout<<(*p).first << " " <<(*p).second <<" \n ";
}
return 0;
}输出:
输入三组名称和数字: Nikita 1001 Deep 2001 Aashi 3001 电话map的大小是:3 电话号码列表: Aashi 3001 Deep 2001 Nikita 1001
在上面的示例中,程序首先使用三个名称交互式创建电话map。然后,它将显示电话map的总大小以及map中可用的所有名称和电话号码。