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中可用的所有名称和电话号码。