C++ set count() 使用方法及示例

C++ STL Set(集合)

C ++ set count()函數用于返回在容器中找到的元素數。由于set容器不包含任何重復元素,因此如果set容器中存在val值的元素,則此函數實際上返回1,否則返回0。

語法

size_type count (const value_type& val) const;

參數

val:要在集合容器中搜索的值。

返回值

如果set容器中存在值val的元素,則返回1,否則返回0。

復雜

大小為對數。

迭代器有效性

沒有變化。

數據爭用

容器被訪問。

同時訪問集合的元素是安全的。

異常安全

如果引發(fā)異常,則容器中沒有任何更改。

實例1

讓我們看一個簡單的示例,使用給定的鍵值搜索元素:

#include <iostream>
#include <set>

using namespace std;
 
int main()
{
    //初始化容器
    set<int> mp;
 
    // 按隨機順序插入元素
    mp.insert(30);
    mp.insert( 40 );
    mp.insert( 60 );
    mp.insert( 20);
    mp.insert( 50 );
 
    // 檢查鍵30是否存在
    if (mp.count(30))
        cout << "鍵30存在\n";
    else
        cout << "鍵30不存在\n";
 
    // 檢查鍵100是否存在
    if (mp.count(100))
        cout << "鍵100存在\n";
    else
        cout << "鍵100不存在\n";
 
    return 0;
}

輸出:

鍵30存在
鍵100不存在

在上面的示例中,count()函數檢查給定值。如果元素存在于集合容器中,則它將顯示消息,指出存在元素,否則不存在。

實例2

讓我們看一個簡單的實例來搜索集合的元素:

#include <iostream>
#include <set>

using namespace std;

int main ()
{
  set<char> myset;
  char c;

  myset = {'a', 'c', 'f'};

  for (c='a'; c<'h'; c++)
  {
    cout << c;
    if (myset.count(c)>0)
      cout << " 是myset的元素。\n";
    else 
      cout << " 不是myset的元素。\n";
  }

  return 0;
}

輸出:

a 是myset的元素。
b 不是myset的元素。
c 是myset的元素。
d 不是myset的元素。
e 不是myset的元素。
f 是myset的元素。
g 不是myset的元素。

在上面的示例中,count()函數用于搜索集合中的“ a”-“ h”元素。

實例3

讓我們看一個簡單的示例來搜索集合中的鍵:

#include <iostream>
#include <set>

using namespace std;

int main(void) {

   set<char> m = {'a','b','c','d'};
            
   if (m.count('a') == 1) {
       cout<< " 'a' 出現在集合中 \n";
   }

   if (m.count('z') == 0) {
      cout << " 'z' 沒有出現在集合中" << endl;
   }

   return 0;
}

輸出:

'a' 出現在集合中
'z' 沒有出現在集合中

在上面的示例中,鍵“ a”出現在集合m中,因此它是“ a”的值,而鍵“ z”不出現在集合中,因此沒有值“ z”。

實例4

讓我們看一個簡單的實例:

#include <set>  
#include <iostream>  
  
int main()  
{  
    using namespace std;  
    set<int> s1;  
    set<int>::size_type i;  
  
    s1.insert(1);  
    s1.insert(1);  
  
    // 鍵在集合中必須是唯一的,所以重復的鍵將被忽略
    i = s1.count(1);  
    cout << "s1中排序鍵為1的元素數為: "  
         << i << "." << endl;  
  
    i = s1.count(2);  
    cout << "s1中排序鍵為2的元素數為: "  
         << i << "." << endl;  
}

輸出:

s1中排序鍵為1的元素數為: 1.
s1中排序鍵為2的元素數為: 0.

C++ STL Set(集合)

丰满人妻一级特黄a大片,午夜无码免费福利一级,欧美亚洲精品在线,国产婷婷成人久久Av免费高清