c++ unordered_set 学习笔记2

来源:unordered_set - C++ Reference (cplusplus.com)

四、element lookup

2.count

size_type count ( const key_type& k ) const;

搜索容器中值为k的元素个数。

由于unorder_set 中不允许重复的元素,因此返回值只要1(k元素存在)或0(k元素不存在)。

五、Modifiers

1.emplace

template <class... Args>
pair <iterator,bool> emplace ( Args&&... args );

插入。与insert方法类似。

由于unorder_set的唯一性,只能插入容器中没有的元素。

插入后元容器size+1。

// unordered_set::emplace
#include <iostream>
#include <string>
#include <unordered_set>

int main ()
{
  std::unordered_set<std::string> myset;

  myset.emplace ("potatoes");
  myset.emplace ("milk");
  myset.emplace ("flour");

  std::cout << "myset contains:";
  for (const std::string& x: myset) std::cout << " " << x;

  std::cout << std::endl;
  return 0;
}

运行结果:

myset contains: flour milk potatoes

2.insert

(1)
pair<iterator,bool> insert ( const value_type& val );
(2)
pair<iterator,bool> insert ( value_type&& val );
(3)
iterator insert ( const_iterator hint, const value_type& val );
(4)
iterator insert ( const_iterator hint, value_type&& val );
(5)
template <class InputIterator>
    void insert ( InputIterator first, InputIterator last );
(6)
void insert ( initializer_list<value_type> il );

// unordered_set::insert
#include <iostream>
#include <string>
#include <array>
#include <unordered_set>

int main ()
{
  std::unordered_set<std::string> myset = {"yellow","green","blue"};
  std::array<std::string,2> myarray = {"black","white"};
  std::string mystring = "red";

  myset.insert (mystring);                        // copy insertion
  myset.insert (mystring+"dish");                 // move insertion
  myset.insert (myarray.begin(), myarray.end());  // range insertion
  myset.insert ( {"purple","orange"} );           // initializer list insertion

  std::cout << "myset contains:";
  for (const std::string& x: myset) std::cout << " " << x;
  std::cout <<  std::endl;

  return 0;
}

运行结果:

myset contains: orange purple white black reddish yellow green blue red  

3.erase

by position (1)
iterator erase ( const_iterator position );
by key (2)
size_type erase ( const key_type& k );
range (3)
iterator erase ( const_iterator first, const_iterator last );

删除元素

按迭代器(位置)删除

按值k删除

按范围删除:注意范围[first,last),前包后不包

// unordered_set::erase
#include <iostream>
#include <string>
#include <unordered_set>

int main ()
{
  std::unordered_set<std::string> myset =
  {"USA","Canada","France","UK","Japan","Germany","Italy"};

  myset.erase ( myset.begin() );                    // erasing by iterator
  myset.erase ( "France" );                         // erasing by key
  myset.erase ( myset.find("Japan"), myset.end() ); // erasing by range

  std::cout << "myset contains:";
  for ( const std::string& x: myset ) std::cout << " " << x;
  std::cout << std::endl;

  return 0;
}

运行结果:

myset contains: Canada UK Italy

4.clear

void clear() noexcept;

清除容器中所有元素。

容器size为0。

unordered_setC++ STL中的一个容器,用于存储一组不重复的元素,其内部实现是基于哈希表的。unordered_set中的元素是无序的,但是可以通过哈希函数快速查找元素。 unordered_set的用法和其他STL容器类似,可以使用insert()函数向其中插入元素,使用erase()函数删除元素,使用find()函数查找元素等。另外,unordered_set还提供了一些其他的成员函数,如size()、empty()、clear()等。 unordered_set的定义方式如下: ```c++ #include <unordered_set> using namespace std; unordered_set<int> mySet; //定义一个存储int类型元素的unordered_set ``` 在使用unordered_set时,需要注意以下几点: 1. unordered_set中的元素必须是可哈希的,即需要定义哈希函数和相等比较函数。 2. unordered_set中的元素是无序的,不能通过下标访问元素。 3. unordered_set中的元素不允许重复,如果插入重复元素会被忽略。 下面是一个使用unordered_set的例子: ```c++ #include <iostream> #include <unordered_set> using namespace std; int main() { unordered_set<int> mySet; mySet.insert(1); mySet.insert(2); mySet.insert(3); mySet.insert(2); //插入重复元素,会被忽略 cout << "mySet size: " << mySet.size() << endl; //输出元素个数 if (mySet.find(2) != mySet.end()) //查找元素2 cout << "2 is in mySet" << endl; else cout << "2 is not in mySet" << endl; mySet.erase(3); //删除元素3 for (auto it = mySet.begin(); it != mySet.end(); ++it) //遍历元素 cout << *it << " "; cout << endl; mySet.clear(); //清空元素 cout << "mySet size: " << mySet.size() << endl; //输出元素个数 return ; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值