STL库之集合基本使用方法

简介: STL库之集合基本使用方法

引言:

集合是数学中的一个概念,集合是由一些不重复的数据组成的。

在C++中我们常用的集合是set


一、引用库

c++中set的实现在一个头文件中,在代码开头引入这个头文件,并且同样加上一句using namespace std


二、构造一个集合

C++中直接构造一个set的语句是:seta.这样我们就定义了一个名为a的、储存数据类型为int的集合(与vector类似)


三、插入元素

使用insert()函数向集合中插入一个新的元素。注意如果结合中已经存在了某个元素,再次插入不会产生任何效果,集合中是不会出现相同元素的

同时用法也和vector一样,需要用集合名去引线


image.png


四、删除元素

用erase()函数删除集合中的一个元素,如果集合中没有和删除的元素,不进行任何操作


image.png


五、判断元素是否存在

直接使用count()函数。如果集合中存在我们要查找的元素,返回1,否则就返回0,尽管count()函数返回值是int类型,但他就返回1或0(所以我们可以使用count函数直接放入循环/判断条件)


六、遍历元素(迭代器的方法)

C++通过迭代器可以访问集合中的每一个元素,迭代器就好像一根手指指向set中的某个元素。通过操作这个手指,我们可以改变它指向的元素。通过*(解引用操作符)操作可以获取迭代器指向的元素。通过++操作让迭代器指向下一个元素,同理--操作让迭代器指向上一个元素。

迭代器的写法比较固定,set::iterator it就定义了指向set这种集合的迭代器it,T是任意的数据类型。其中::iterator是固定的写法。begin函数返回容器中其实元素的迭代器,end函数返回容器的尾后迭代器。(尾后迭代器表示在end后面一位的元素)


image.png最好先记住迭代器于for循环中使用的方法


#include<set>//数据结构set的头文件
#include<string>
using namespace std;//一定不要忘
int main()
{
  set<string> country;//{ }定义set
  country.insert("china");//{"china"}插入元素China
  country.insert("america");//{"China","American"}插入元素American
  country.insert("france");
  country.erase("france");//清空集合中某一个具体的元素
  for (set<string>::iterator it=country.begin();it!=country.end();it++)//迭代器使用的方法,先记住!
  {
    cout << *it << ' ';
  }
  return 0;
}

最好先记住迭代器于for循环中使用的方法


七、清空

clear()函数用于清空set,同时会清空set所占的内存

相关文章
|
7月前
|
存储 算法 C++
【C++】STL的基本用法
【C++】STL的基本用法
79 0
|
算法 Python
【Python深入学习】- 书籍推荐|数据结构和算法介绍|内建集合数据类型
【Python深入学习】- 书籍推荐|数据结构和算法介绍|内建集合数据类型
90 1
|
6月前
|
算法 Linux C语言
7.学习STL和string类:版本、组件、构造、操作及应用
7.学习STL和string类:版本、组件、构造、操作及应用
|
7月前
|
存储 算法 C++
C++ STL库的介绍和使用(下)
C++ STL库的介绍和使用
53 1
|
7月前
|
索引 Python
python学习-函数模块,数据结构,字符串和列表(上)
python学习-函数模块,数据结构,字符串和列表
51 0
|
7月前
|
存储 算法 前端开发
C++ STL库的介绍和使用(上)
C++ STL库的介绍和使用
87 0
|
7月前
|
算法 Python
Python高级数据结构——并查集(Disjoint Set)
Python高级数据结构——并查集(Disjoint Set)
333 2
|
7月前
|
编译器 C++
C++之STL库:string类(用法列举和总结)
C++之STL库:string类(用法列举和总结)
|
C++ 容器
STL 基本操作(包含所有基本的函数功能)
STL 基本操作(包含所有基本的函数功能)
93 0
|
存储 算法 C语言
STL库之动态数组vector基本使用方法
STL库之动态数组vector基本使用方法