C++STL中集合set的底层实现和常用操作

STL其他内容解析:关于C++中STL的理解和应用


目录

set简介:

set的底层实现:红黑树

常用操作:

自定义set:

应用:去重


set简介:

Set是一种包含已排序对象的关联容器。

set/multiset会根据待定的排序准则,自动将元素排序。两者不同在于前者不允许元素重复,而后者允许。

set的特点:
1) 不能直接改变元素值,因为那样会打乱原本正确的顺序,要改变元素值必须先删除旧元素,则插入新元素
2) 不提供直接存取元素的任何操作函数,只能通过迭代器进行间接存取,而且从迭代器角度来看,元素值是常数
3) 元素比较动作只能用于型别相同的容器(即元素和排序准则必须相同)

只是插入,删除,查找的话,set / map在c++ 11引入unordered_set / unordered_map后这方面意义就不大了。。。但set由于是红黑树实现,可以保证内部元素的有序,可以提供对数复杂度下集合内最接近给定值的的元素,或者快速输出top k大等。。。

set中每个元素只包含一个关键字:set支持高效的关键字查询操作----检查一个给定关键字是否在set中(find函数,复杂度lgN)。集合set和数学上的集合是一致的,每个元素最多只出现一次,并且是排好序的,和sort一样,自定义类型也可以构造set,但同样必须定义<运算符。

set的底层实现:红黑树

为什么不用hash?

首先set,不像map那样是key-value对,它的key与value是相同的。关于set有两种说法,第一个是STL中的set,用的是红黑树;第二个是hash_set,底层用得是hash table。红黑树与hash table最大的不同是,红黑树是有序结构,而hash table不是。但不是说set就不能用hash,如果只是判断set中的元素是否存在,那么hash显然更合适,因为set 的访问操作时间复杂度是log(N)的,而使用hash底层实现的hash_set是近似O(1)的。然而,set应该更加被强调理解为“集合”,而集合所涉及的操作并、交、差等,即STL提供的如交集set_intersection()、并集set_union()、差集set_difference()和对称差集set_symmetric_difference在。(),都需要进行大量的比较工作,那么使用底层是有序结构的红黑树就十分恰当了,这也是其相对hash结构的优势所

常用操作:

begin();            // 返回指向第一个元素的迭代器
end();              // 返回指向最后一个元素的迭代器
clear();            // 清除所有元素
count();            // 返回某个值元素的个数
 
empty();            // 如果集合为空,返回true
 
equal_range();      //返回集合中与给定值相等的上下限的两个迭代器
 
erase()–删除集合中的元素
 
find()–返回一个指向被查找到元素的迭代器
 
get_allocator()–返回集合的分配器
 
insert()–在集合中插入元素
 
lower_bound()–返回指向大于(或等于)某值的第一个元素的迭代器
 
key_comp()–返回一个用于元素间值比较的函数
 
max_size()–返回集合能容纳的元素的最大限值
 
rbegin()–返回指向集合中最后一个元素的反向迭代器
 
rend()–返回指向集合中第一个元素的反向迭代器
 
size()–集合中元素的数目
 
swap()–交换两个集合变量
 
upper_bound()–返回大于某个值元素的迭代器
 
value_comp()–返回一个用于比较元素间的值的函数

 

自定义set:

从大到小排序:

    set<int,greater<int> > a;

自定义结构:

        struct Info
        {
            string name;
            float score;
            //重载“<”操作符,自定义排序规则
            bool operator < (const Info &a) const
            {
                //按score从大到小排列
                return a.score<score;
            }
        }
        set<Info> s;
        ......
        set<Info>::iterator it;

 

应用:去重

简单的插入,迭代器遍历,统计函数。

#include<iostream>
#include<algorithm>
#include<set>
using namespace std;

set<int,greater<int> > a;

int main(){
	a.insert(2);
	a.insert(0);
	a.erase(2);
	a.insert(110);
	set<int,greater<int> >::iterator it;
	for (it=a.begin(); it!=a.end(); it++){
		cout<<*it<<" ";
	}
	cout<<a.count(11)<<endl;
 } 

给vector去重  assign函数

#include<set>
#include<vector>
#include<iostream>
using namespace std;

int main(){
	vector<int> vec;
	vec.push_back(5);
	vec.push_back(6);	
	vec.push_back(2);
	vec.push_back(3);
	vec.push_back(1);
				
	set<int> st(vec.begin(), vec.end());
	vec.assign(st.begin(), st.end());
	
	vector<int>::iterator it;
	for (it = vec.begin(); it != vec.end(); it++)
	cout << *it<<endl;
	return 0;
}

应用set的题目:https://blog.csdn.net/qq_33266320/article/details/90210148

 

 

  • 7
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: C++ STL(Standard Template Library)是一种功能强大的库,提供了一套丰富的数据结构和算法实现。在余文溪的《C++ STL数据结构与算法实现》这本PDF书,详细介绍了STL的各种数据结构和算法的实现。 首先,STL提供了几种基本的数据结构,例如vector(动态数组)、list(双向链表)、deque(双端队列)、set集合)、map(映射)等。这些数据结构在STL都有相应的实现操作函数,能够方便地进行插入、删除、查找等操作。 此外,STL还提供了一些算法,包括排序、查找、遍历等等。这些算法可以应用于STL的各种数据结构上,提供了一种高效且易用的方式来处理数据。例如,STL提供了排序算法sort,可以对vector、list等容器进行排序操作;还有查找算法find,可以在set、map等容器进行查找操作。 在《C++ STL数据结构与算法实现,余文溪详细阐述了STL实现原理和内部细节,帮助读者深入理解STL的工作原理。通过学习这本书,读者可以了解到STL的设计思想、使用方法和性能特点,从而能够更好地应用STL解决问题。 总而言之,STL提供了一套强大的数据结构和算法实现,通过余文溪的《C++ STL数据结构与算法实现》这本PDF书,读者可以深入了解STL的使用方法和内部原理,提升编程能力。 ### 回答2: C++ STL(Standard Template Library,标准模板库)是C++标准库的一部分,为我们提供了丰富的数据结构和算法实现。余文溪编写的《C++ STL 数据结构域算法实现》PDF是一本介绍STL的经典教材。 STL包含了很多常用的数据结构,例如向量(vector)、链表(list)、集合set)和映射(map)等。这些数据结构都已经被封装好,通过STL可以方便地进行插入、删除、查找等操作。同时,STL还提供了强大的算法库,例如排序、查找、拷贝和逆序等。使用STL的数据结构和算法,可以极大地提高我们的编程效率。 《C++ STL 数据结构域算法实现》是一本很好的学习STL的教材。其,余文溪详细地介绍了STL的各种数据结构和算法,通过代码示例和讲解,深入浅出地帮助读者理解STL的使用方法。这本教材适合初学者和有一定基础的读者阅读,对于了解STL的基本概念和使用方法非常有帮助。 在读完《C++ STL 数据结构域算法实现》后,读者将能够熟练使用STL提供的数据结构和算法,加快自己的编程效率。同时,通过掌握STL的使用,读者也能更好地理解C++标准库的设计思想和使用方法,提升自己的编程水平。 总之,《C++ STL 数据结构域算法实现》是值得一读的一本STL教材,能够帮助我们更好地学习和应用STL,提高我们的编程效率和水平。 ### 回答3: STL(Standard Template Library)是C++的标准库之一,提供了丰富的数据结构和算法实现。而余文溪编写的《C++ STL数据结构与算法实现》这本PDF书籍主要介绍了STL的使用方法和内部实现原理。 该书首先介绍了STL的基本概念和使用方法,包括迭代器、容器、算法等方面的内容。通过对各种容器(如vector、list、set、map等)和算法(如排序、查找、合并等)的讲解,读者可以了解到STL的强大功能和高效性。 此外,余文溪在书也深入探讨了STL的内部实现原理。他通过剖析STL的源代码,详细解释了其的数据结构和算法实现细节。这对于希望深入理解STL底层机制的读者来说,是非常有价值的。 《C++ STL数据结构与算法实现》这本书的另一个特点是提供了大量的示例代码和实战练习。通过实际编写代码和完成练习,读者可以巩固所学知识,并提升自己的编程能力。 总之,余文溪的这本PDF书籍对于想要掌握STL的使用方法和底层实现原理的C++程序员来说,是一本非常实用的工具书。无论是初学者还是有一定经验的开发者,都可以从获得很多有价值的知识和技能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值