C++ map size() 函数使用方法及示例

C++ STL map(容器)

C ++ map size()函数用于查找map容器中存在的元素数。

语法

成员类型size_type是无符号整数类型。

size_type size() const; //  在 C++ 11 之前
size_type size() const noexcept; //从 C++ 11 开始

参数

没有

返回值

它返回map中存在的元素数。

实例1

让我们看一个简单的示例来计算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个元素。

实例2

让我们看一个简单的示例,计算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。

实例3

让我们看一个简单的实例。

#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的大小为止。

实例4

让我们看一个简单的实例。

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

C++ STL map(容器)