c++中容器set的去除重复元素排序

c++ stl集合set介绍

   c++ stl集合(Set)是一种包含已排序对象的关联容器。set/multiset会根据待定的排序准则,自动将元素排序。两者不同在于前者不允许元素重复,而后者允许。

1) 不能直接改变元素值,因为那样会打乱原本正确的顺序,要改变元素值必须先删除旧元素,则插入新元素

2) 不提供直接存取元素的任何操作函数,只能通过迭代器进行间接存取,而且从迭代器角度来看,元素值是常数

3) 元素比较动作只能用于型别相同的容器(即元素和排序准则必须相同)

set模板原型://Key为元素(键值)类型

template <class Key, class Compare=less<Key>, class Alloc=STL_DEFAULT_ALLOCATOR(Key) >

从原型可以看出,可以看出比较函数对象及内存分配器采用的是默认参数,因此如果未指定,它们将采用系统默认方式。

 

set的各成员函数列表如下:

c++ stl容器set成员函数:begin()--返回指向第一个元素的迭代器

c++ stl容器set成员函数:clear()--清除所有元素

c++ stl容器set成员函数:count()--返回某个值元素的个数

c++ stl容器set成员函数:empty()--如果集合为空,返回true

c++ stl容器set成员函数:end()--返回指向最后一个元素的迭代器

c++ stl容器set成员函数:equal_range()--返回集合中与给定值相等的上下限的两个迭代器

c++ stl容器set成员函数:erase()--删除集合中的元素

c++ stl容器set成员函数:find()--返回一个指向被查找到元素的迭代器

c++ stl容器set成员函数:get_allocator()--返回集合的分配器

c++ stl容器set成员函数:insert()--在集合中插入元素

c++ stl容器set成员函数:lower_bound()--返回指向大于(或等于)某值的第一个元素的迭代器

c++ stl容器set成员函数:key_comp()--返回一个用于元素间值比较的函数

c++ stl容器set成员函数:max_size()--返回集合能容纳的元素的最大限值

c++ stl容器set成员函数:rbegin()--返回指向集合中最后一个元素的反向迭代器

c++ stl容器set成员函数:rend()--返回指向集合中第一个元素的反向迭代器

c++ stl容器set成员函数:size()--集合中元素的数目

c++ stl容器set成员函数:swap()--交换两个集合变量

c++ stl容器set成员函数:upper_bound()--返回大于某个值元素的迭代器

c++ stl容器set成员函数:value_comp()--返回一个用于比较元素间的值的函数

 

c++ stl集合set插入,遍历用法举例

#include<iostream> 
#include<set> 
using namespace std; 
//set插入元素操作  
int main() 
{ 
    //定义一个int型集合对象s,当前没有任何元素.由www.169it.com搜集整理
    set<int> s; 
    s.insert(8);  //第一次插入8,可以插入  
    s.insert(1); 
    s.insert(12); 
    s.insert(6); 
    s.insert(8);   //第二次插入8,重复元素,不会插入  
    set<int>::iterator it; //定义前向迭代器 
    //中序遍历集合中的所有元素  
    for(it=s.begin();it!=s.end();it++) 
    cout<<*it<<endl;    
    system("pause"); 
    return 0; 
}

 

  • 1
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
### 回答1: 在Pythonset是一种可变的、无序的集合类型,其每个元素都是唯一的,不允许重复。可以使用set来执行多种集合操作,例如交集、并集和差集。 以下是一些使用set的示例: 1. 创建一个set: ``` my_set = {1, 2, 3} ``` 或者: ``` my_set = set([1, 2, 3]) ``` 2. 向set添加元素: ``` my_set.add(4) ``` 3. 从set删除元素: ``` my_set.remove(3) ``` 4. 求两个set的交集: ``` set1 = {1, 2, 3} set2 = {2, 3, 4} intersection = set1.intersection(set2) ``` 5. 求两个set的并集: ``` set1 = {1, 2, 3} set2 = {2, 3, 4} union = set1.union(set2) ``` 6. 求两个set的差集: ``` set1 = {1, 2, 3} set2 = {2, 3, 4} difference = set1.difference(set2) ``` 7. 判断一个元素是否在set: ``` if 1 in my_set: print("1 is in the set") ``` 总之,set是一个非常有用的Python内置类型,可以帮助我们执行多种集合操作,特别是去除重复元素的时候非常方便。 ### 回答2: C++set是一个容器,用于存储一组唯一的元素,且按照升序排序。下面是关于set容器的用法: 1. 包含头文件:首先需要包含头文件<set>。 2. 创建set对象:使用关键字set创建set对象,可以指定元素类型和排序规则。例如,创建一个存储整数的set对象:set<int> mySet; 3. 插入元素:使用insert()函数将元素插入到set容器。例如,将元素5插入到mySet:mySet.insert(5); 4. 访问元素set不支持直接访问元素,因为set元素是按照排序规则存储的。可以使用迭代器进行遍历和访问元素。例如,遍历并打印mySet的所有元素: ``` for(auto it = mySet.begin(); it != mySet.end(); ++it) { cout << *it << " "; } ``` 5. 删除元素:使用erase()函数可以删除set的指定元素。例如,删除元素5:mySet.erase(5); 6. 查找元素:使用find()函数可以查找set是否包含指定元素。该函数返回一个迭代器,指向要查找的元素。如果元素存在,则返回指向该元素的迭代器;否则,返回set的end()迭代器。 7. 其他操作:除了上述常用操作外,set还支持很多其他操作,例如计数元素个数、清空容器、合并两个set等。详细的操作可以参考C++set文档。 注意事项: - set元素是唯一的,重复元素将不会被插入。 - set元素是有序的,插入和删除操作的时间复杂度较低。 这是关于set容器的简要用法说明,希望对你有所帮助! ### 回答3: C++set容器是一个内部元素重复、自动排序容器。它位于<set>头文件,可以使用以下步骤来使用set容器: 1. 包含头文件:<set> 在使用set容器之前,需要包含<set>头文件。 2. 声明set容器: 使用set容器之前,需要声明一个set对象。可以根据需要指定元素类型,也可以使用默认的less比较函数进行元素的比较。 ``` set<int> mySet; // 声明一个存储int类型的set容器 set<string> mySet; // 声明一个存储string类型的set容器 ``` 3. 插入元素: 使用insert()函数向set容器插入元素set容器会自动进行元素排序,且不会有重复元素。 ``` mySet.insert(10); // 向set容器插入元素10 mySet.insert(20); // 向set容器插入元素20 mySet.insert(30); // 向set容器插入元素30 // 重复元素将不会被插入 mySet.insert(10); // 不会向set容器插入重复元素10 ``` 4. 遍历元素: 可以使用迭代器或者范围for循环遍历set容器元素。 ``` for(auto iter = mySet.begin(); iter != mySet.end(); ++iter) { cout << *iter << " "; // 输出set容器元素 } // 或者使用范围for循环 for(const auto& element : mySet) { cout << element << " "; // 输出set容器元素 } ``` 5. 使用set容器的其他操作: set容器提供了许多其他操作,如查找元素、删除元素、判断元素是否存在等。可以根据具体需求选用合适的函数进行操作。 以上就是使用set容器的基本步骤,通过这些步骤可以方便地使用set容器实现元素重复、有序的存储和访问。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值