C++笔记之set使用

set有元素唯一性,自动排序。 

1.常用操作

插入:se.insert(5);

访问:只能通过迭代器,*it 

查找:it=se.find(3),返回元素对应的迭代器,若未找到,返回se.end()

删除:se.erase(4),删除值为5的元素;
           se.erase(it),删除迭代器指定的元素。

判空:se.empty(),若为空,返回1;若不空,返回0.

清空:se.clear(). 

2.成员函数列表

1. begin()--返回指向第一个元素的迭代器

2. clear()--清除所有元素

3. count()--返回某个值元素的个数

4. empty()--如果集合为空,返回true

5. end()--返回指向最后一个元素的迭代器

6. equal_range()--返回集合中与给定值相等的上下限的两个迭代器

7. erase()--删除集合中的元素

8. find()--返回一个指向被查找到元素的迭代器

9. get_allocator()--返回集合的分配器

10. insert()--在集合中插入元素

11. lower_bound()--返回指向大于(或等于)某值的第一个元素的迭代器

12. key_comp()--返回一个用于元素间值比较的函数

13. max_size()--返回集合能容纳的元素的最大限值

14. rbegin()--返回指向集合中最后一个元素的反向迭代器

15. rend()--返回指向集合中第一个元素的反向迭代器

16. size()--集合中元素的数目

17. swap()--交换两个集合变量

18. upper_bound()--返回大于某个值元素的迭代器

19. value_comp()--返回一个用于比较元素间的值的函数

3 代码示例

#include<iostream>
#include<set>

using namespace std;

int main(){

//1.元素类型为int
	int a[5]={1,0,3,2,4};
	set<int> se1(a,a+5);
	
	//插入
	se1.insert(5);	
	se1.insert(2);//无法插入已有的值 
	
	//输出
	cout<<"元素个数为:"<<se1.size()<<endl;
	set<int>::iterator it1;
	for(it1=se1.begin();it1!=se1.end();it1++) cout<<*it1<<' ';
	cout<<endl<<endl; 
	
	//访问
//	cout<<se1[2]<<endl;//不可行 
	it1=se1.begin();
	cout<<*it1<<endl; 
	cout<<endl;
	
	//查找
	it1=se1.find(3);
	if(it1!=se1.end()) cout<<"找到元素3"<<endl; 
	cout<<endl;
	
	//删除
	se1.erase(4);
	it1=se1.begin();
	se1.erase(it1); 
	cout<<"元素个数为:"<<se1.size()<<endl;
	for(it1=se1.begin();it1!=se1.end();it1++) cout<<*it1<<' ';
	cout<<endl<<endl;
	
	//判空、清空
	cout<<"set空吗:"<<se1.empty()<<endl;
	se1.clear();
	cout<<"set空吗:"<<se1.empty()<<endl; 

/*---------------------------------------------------------------------------*/ 
cout<<endl<<"=================================================================="<<endl<<endl; 
/*---------------------------------------------------------------------------*/ 

//2.元素类型为string 
	//string a[5]={"aaa","bbb","ccc","ddd","eee"};
	//set<string> sset(a,a+5);	//不可行 
	set<string> sset;
	
	//插入
	sset.insert("cbc");
	sset.insert("cac");
	sset.insert("aaa");
	sset.insert("bbb");
	sset.insert("ddd");
	sset.insert("fff");	
	
	sset.insert("bbb");//无法插入已有的值 
 
 	//输出
	cout<<"元素个数为:"<<sset.size()<<endl;
	set<string>::iterator it2;
	for(it2=sset.begin();it2!=sset.end();it2++) cout<<*it2<<' ';
	cout<<endl<<endl; 
 
 	//访问
	it2=sset.begin();
	cout<<*it2<<endl; 
	cout<<endl;
 
 	//查找
	it2=sset.find("ccc");
	if(it2!=sset.end()) cout<<"找到元素ccc"<<endl; 
	else cout<<"未找到ccc"<<endl; 
	cout<<endl;
	
	//删除
	sset.erase("ddd");
	it2=sset.begin();
	sset.erase(it2); 
	cout<<"元素个数为:"<<sset.size()<<endl;
	for(it2=sset.begin();it2!=sset.end();it2++) cout<<*it2<<' ';
	cout<<endl<<endl;
	
	//判空、清空
	cout<<"set空吗:"<<sset.empty()<<endl;
	sset.clear();
	cout<<"set空吗:"<<sset.empty()<<endl; 
	
	return 0;
}

运行结果:


参考

https://www.cnblogs.com/omelet/p/6627667.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

禺垣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值