algorithm(set)

set是一个内部自动有序并且不含重复元素的容器。可以用set保留元素本身而不用考虑它的个数;

加入set之后客户已实现自动排序;

首先要想使用set就要加上set头文件:#include<set>;

还需要在头文件下面加上一句:using namespace std;

1、set的定义:

set<typename> name;

其定义和vector基本一样,或者说大部分STL都是这样定义的,这里面的typename可以是任何基本类型,

也可以是STL标准容器:vector,set,queue等;

2、set容器内元素的访问:

set只可以通过迭代器(iterator)访问:

set<typename>::iterator it;

这样就可得到迭代器it,并且可以通过*it来访问set内的元素;

#include<iostream>
#include<algorithm>
#include<set>
#include<cstdio>
using namespace std;
int get_sum(int input){
	int sum=0;
	while(input>0){
		sum+=input%10;
		input/=10;
	}
	return sum;
}
int main()
{
	#ifdef ONLINE_JUDGE
	#else
	freopen("in.txt","r",stdin);
	freopen("out.txt","w",stdout);
	#endif
	set<int> ans;
	int n;
	cin>>n;
	int input;
	for(int i=0;i<n;i++){
		cin>>input;
		ans.insert(get_sum(input));
		
	}
	cout<<ans.size()<<endl;
	set<int>::iterator it=ans.begin();
	for(;it!=ans.end();it++){
		if(it==ans.begin()){
			cout<<*it;
		}else{
			cout<<" "<<*it;
		}
	}
	cout<<endl;
	return 0;
	
}
输入:

8
123 899 51 998 27 33 36 12

输出:

4
3 6 9 26

由输出可看:按照递增排序的,并自动去除重复元素(题目来自pat乙级1064)

3、set常用函数:(n是set内元素的个数)

insert(x);

将x插入到set容器中,并自动递增排序和去重,时间复杂度O(logn);

find(value);

返回set中对应值为value的迭代器(迭代器可以看做一种类似于指针的东西),时间复杂度O(logn);

erase():

用法有两种,一个是删除单个元素,一个是删除一个区间内的所有元素;

size();

可以用来获得set内的元素的个数;

clear();

用来清空set内部所有元素;


注:set最主要作用是自动去重,并按照升序排序,因此碰到需要去重但是却不方便直接开数组的情况可以用set;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值