集合:

集合是由元素组成的一个类,其成员可以是一个集合,也可以是一个原子,通常一个元素在一个集合中不能多次出现;由于对实现集合不是很理解,只简单写下已有的STL中的set集合使用;

C++中set基本运算及操作:

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

clear():清除所有元素;

empty():判断集合是否为空,若为空,返回true;

end():返回指向最后一个元素的迭代器;

size():返回集合中元素的数目;

lower_bound():返回指向大等于某值的第一个元素的迭代器;

set_union():合并两个集合;

set_intersection():两个集合的交集;

set_difference():前面集合对后面集合的差集;

合并集合:

调用代码:
#include<cstdio>
#include<cstdlib>
#include<algorithm>
#include<iostream>
#include<set>
using namespace std;
struct Stu
{
int ID;
int val;
};
struct cmp
{
bool operator()(const Stu& t1, const Stu& t2)
{
if (t1.val<t2.val)return true;
else if (t1.val == t2.val)
{
if (t1.ID<t2.ID)return true;
}
else return false;
}
};
int main()
{
set<Stu, cmp>s1;
set<int>s2;
set<int>s3;
set<int>uni;
set<int>inter;
set<int>dif;
Stu stu1, stu2, stu3;
stu1.val = 80; stu2.val = 85; stu3.val = 85;
stu1.ID = 31602114; stu2.ID = 31602113; stu3.ID = 31602115;
s1.insert(stu1); s1.insert(stu2); s1.insert(stu3);
s2.insert(10); s2.insert(13); s2.insert(54); s2.insert(7);
s3.insert(1);s3.insert(12);s3.insert(54);s3.insert(13);
printf("整型数据输出:\n");
set<int>::iterator int_iter;
set<Stu, cmp>::iterator Stu_iter;
for (int_iter = s2.begin(); int_iter != s2.end(); int_iter++)
printf("%d ", *int_iter);
printf("\n\n");
printf("自定义数据输出:\n");
for (Stu_iter = s1.begin(); Stu_iter != s1.end(); Stu_iter++)
printf("学号:%d 成绩:%d\n", Stu_iter->ID, Stu_iter->val);
printf("\n\n");
printf("并集,交集,差集函数使用:\n");
set<int>::iterator s;
set_union(s2.begin(),s2.end(),s3.begin(),s3.end(),inserter(uni,uni.begin())); //s2与s3的并集 ,放入到uni中了 ;
set_intersection(s2.begin(),s2.end(),s3.begin(),s3.end(),inserter(inter,inter.begin())); //s2与s3的交集 ,放入到inter中了;
set_difference(s2.begin(),s2.end(),s3.begin(),s3.end(),inserter(dif,dif.begin())); //s2对s3的差集 ,放入到dif中了;
for(s=uni.begin();s!=uni.end();s++)
printf("%d,",*s);
printf("\n");
for(s=inter.begin();s!=inter.end();s++)
printf("%d,",*s);
printf("\n");
for(s=dif.begin();s!=dif.end();s++)
printf("%d,",*s);
printf("\n"); return 0;
}

这里讲到lower_bound就简要写一下lower_bound的使用:假设存在一个数组num[]:5,16,19,75,94,101;位置变量pos;

pos=lower_bound(num,num+6,15);

即pos返回的是第一个比15大等的元素的位置,此时pos=1;

pos=lower_bound(num,num+6,110);

pos是返回第一个比110大等的元素的位置,若不存在,则返回最右端元素的下一位下标,即size;此时pos=6;

lower_bound的核心思想:使用二分法对元素进行查找;

大致实现源代码:
//这个算法中,first是最终要返回的位置
int lower_bound(int *array, int size, int key)
{
int first = 0, middle;
int half, len;
len = size; while(len > 0) {
half = len >> 1;
middle = first + half;
if(array[middle] < key) {
first = middle + 1;
len = len-half-1; //在右边子序列中查找
}
else
len = half; //在左边子序列(包含middle)中查找
}
return first;
}

还有需要自己实现的集合代码没有学习,之后有空再补上吧;

最新文章

  1. [deviceone开发]-心形点赞动画示例
  2. Spark作业调度阶段分析
  3. Utility1:Overview
  4. php广告图片循环播放 幻灯片效果
  5. 几种排序算法的学习,利用Python和C实现
  6. ubuntu 搭建PPTP VPN服务器
  7. URL和URI的区别和联系
  8. JDBC常用接口详解
  9. Linux系统管理员踢用户的方法
  10. 回调的代理(delegate)实现
  11. 自动生成XML反序列化的类
  12. A Tour of Go Switch
  13. JS为Select下拉框添加输入功能
  14. 转:git windows中文 乱码问题解决汇总
  15. Spring mybatis源码篇章-MybatisDAO文件解析(二)
  16. ①bootstrap引入
  17. Python内置函数(39)——help
  18. MySQL执行原理,逻辑分层、更改数据库处理引擎
  19. table 表格固定表头和第一列、内容可滚动
  20. 使用BFG移除git库中的大文件或污点提交

热门文章

  1. 关于SignalR连接数量问题的记录
  2. 20155217 2016-2017-2 《Java程序设计》第7周学习总结
  3. OSG漫游到指定坐标点位置
  4. MySQL下建立表
  5. 【HNOI2013】数列
  6. win8.1下右下角出现大小写切换状态显示框解决方案
  7. UWP 剪贴板 Clipboard
  8. asp.net core发布到docker报Microsoft.ApplicationInsights.AspNetCore miss的错误
  9. STM8S——Flash program memory and data EEPROM
  10. pycharm专业版激活码