STL学习笔记(已序区间算法)
针对已序区间执行的算法,执行前提是源区间必须在某个排序准则下已序。
搜寻元素(Searching)
1.检查某个元素是否存在
bool
binary_search(ForwardIterator beg,ForwardIterator end,
const T& value)
bool
binary_search(ForwardIterator beg,ForwardIterator end,
const T& value,
BinaryPredicate op)
以下示范binary_search()的用法
#include "algostuff.hpp"
using namespace std; int main()
{
list<int> coll;
INSERT_ELEMENTS(coll,,);
PRINT_ELEMENTS(coll);
if(binary_search(coll.begin(),coll.end(),))
cout<<"5 is present"<<endl;
else
cout<<"5 is not present"<<endl;
if(binary_search(coll.begin(),coll.end(),))
cout<<"42 is present"<<endl;
else
cout<<"42 is not present"<<endl;
}
2.检查若干值是否存在
bool
includes(InputIterator beg,
InputIterator end,
InputIterator searchBeg,
InputIterator searchEnd)
bool
includes(InputIterator beg,
InputIterator end,
InputIterator searchBeg,
InputIterator searchEnd,
BinaryPredicate op)
两种形式都用来判断已序区间[beg,end)是否包含另一已序区间[searchBeg,searchEnd)的全部元素
以下程序示范inlcudes()的用法
#include "algostuff.hpp"
using namespace std; int main()
{
list<int> coll;
vector<int> search;
INSERT_ELEMENTS(coll,,);
PRINT_ELEMENTS(coll,"coll: ");
search.push_back();
search.push_back();
search.push_back();
PRINT_ELEMENTS(search,"search: ");
if(includes(coll.begin(),coll.end(),search.begin(),search.end()))
cout<<"all elements of search are also in coll"<<endl;
else
cout<<"not all elements of search are also in coll"<<endl;
}
3.搜寻第一个或最后一个可能位置
ForwardIterator
lower_bound(ForwardIterator beg,ForwardIterator end,const T& value)
ForwardIterator
lower_bound(ForwardIterator beg,ForwardIterator end,const T& value,
BinaryPredicate op)
ForwardIterator
upper_bound(ForwardIterator beg,ForwardIterator end,const T& value)
ForwardIterator
upper_bound(ForwardIterator beg,ForwardIterator end,const T& value,
BinaryPredicate op)
1.lower_bound()返回第一个“大于等于value”的元素位置。
2.upper_bound()返回第一个“大于value”元素的位置
以下程序示范lower_bound()和upper_bound()的用法
#include "algostuff.hpp"
using namespace std; int main()
{
list<int> coll;
INSERT_ELEMENTS(coll,,);
INSERT_ELEMENTS(coll,,);
coll.sort();
PRINT_ELEMENTS(coll);
list<int>::iterator pos1,pos2;
pos1=lower_bound(coll.begin(),coll.end(),);
pos2=upper_bound(coll.begin(),coll.end(),);
cout<<"5 could get position "
<<distance(coll.begin(),pos1)+
<<" up to "
<<distance(coll.begin(),pos2)+
<<" without breaking the sorting"<<endl;
coll.insert(lower_bound(coll.begin(),coll.end(),),);
coll.insert(upper_bound(coll.begin(),coll.end(),),);
PRINT_ELEMENTS(coll);
}
3.搜寻第一个和最后一个可能位置
pair<ForwardIterator,ForwardIterator>
equal_range(ForwardIterator beg,ForwardIterator end,const T& value)
pair<ForwardIterator,ForwardIterator>
equal_range(ForwardIterator beg,ForwardIterator end,const T& value,
BinaryPredicate op)
返回值与下式等效: make_pair(lower_bound(...),upper_bound(...))
以下程序展示equal_range()的用法
#include "algostuff.hpp"
using namespace std; bool bothEvenOrOdd(int elem1,int elem2)
{
return elem1%==elem2%;
} int main()
{
vector<int> coll1;
list<int> coll2;
INSERT_ELEMENTS(coll1,,);
INSERT_ELEMENTS(coll2,,);
PRINT_ELEMENTS(coll1,"coll1: ");
PRINT_ELEMENTS(coll2,"coll2: ");
if(equal(coll1.begin(),coll1.end(),coll2.begin()))
cout<<"coll1==coll2"<<endl;
else
cout<<"coll1!=coll2"<<endl;
if(equal(coll1.begin(),coll1.end(),coll2.begin(),bothEvenOrOdd))
cout<<"even and odd elements correspond"<<endl;
else
cout<<"even and odd elements do not correspond"<<endl;
}
合并元素(Merging)
1.两个已序集合的总和
OutputIterator
merge(InputIterator source1Beg,InputIterator source1End,
InputIterator source2Beg,InputIterator source2End,
OutputIterator destBeg)
OutputIterator
merge(InputIterator source1Beg,InputIterator source1End,
InputIterator source2Beg,InputIterator source2End,
OutputIterator destBeg,BinaryPredicate op)
1.两者都是将两个源区间的元素合并,使得“以destBeg起始的目标区间”内含两个源区间所有元素。
2.目标区间内的所有元素都将按顺序排序
下面这个例子展示merge()的用法
#include <iterator>
#include "algostuff.hpp"
using namespace std; int main()
{
list<int> coll1;
set<int> coll2;
INSERT_ELEMENTS(coll1,,);
INSERT_ELEMENTS(coll2,,);
PRINT_ELEMENTS(coll1,"coll1: ");
PRINT_ELEMENTS(coll2,"coll2: ");
cout<<"merged: ";
merge(coll1.begin(),coll1.end(),coll2.begin(),coll2.end(),ostream_iterator<int>(cout," "));
cout<<endl;
}
2.两个已序集合的并集
OutputIterator
set_union(InputIterator source1Beg,InputIterator source1End,
InputIterator source2Beg,InputIterator source2End,
OutputIterator destBeg)
OutputIterator
set_union(InputIterator source1Beg,InputIterator source1End,
InputIterator source2Beg,InputIterator source2End,
OutputIterator destBeg,BinaryPredicate op)
与merge不一样的是,目标区间的元素要不来自第一源区间,要不就来自第二源区间,或是同时来自两个源区间。例如:
source1:1 2 2 4 6 7 7 9
source2:2 2 2 3 6 6 8 9
dest:1 2 2 2 3 4 6 6 7 7 8 9
3.两个已序集合的交集
OutputIterator
set_intersection(InputIterator source1Beg,InputIterator source1End,
InputIterator source2Beg,InputIterator source2End,
OutputIterator destBeg)
OutputIterator
set_intersection(InputIterator source1Beg,InputIterator source1End,
InputIterator source2Beg,InputIterator source2End,
OutputIterator destBeg,BinaryPredicate op)
4.两个已序集合的差集
OutputIterator
set_difference(InputIterator source1Beg,InputIterator source1End,
InputIterator source2Beg,InputIterator source2End,
OutputIterator destBeg)
OutputIterator
set_difference(InputIterator source1Beg,InputIterator source1End,
InputIterator source2Beg,InputIterator source2End,
OutputIterator destBeg,BinaryPredicate op)
目标区间的元素只存在于第一源区间,不存在与第二源区间。
STL学习笔记(已序区间算法)的更多相关文章
- Effective STL 学习笔记 31:排序算法
Effective STL 学习笔记 31:排序算法 */--> div.org-src-container { font-size: 85%; font-family: monospace; ...
- STL学习笔记7 ---- algorithm(算法)
STL中算可以分为三种, 1.变序型队列算法,可以改变容器内的数据: 2.非变序型队列算法,处理容器内的数据而不改变他们 : 3.通用数值算法,这涉及到很多专业领域的算术操作,这里不做介绍. 第一是变 ...
- STL学习笔记(非变动性算法)
辅助函数 本节跟以后几节将对所有STL算法逐一详细讨论.为了简化这些例子,我们使用了一些辅助函数,分别用于对容器进行输出跟插入操作. #ifndef ALGOSTUFF_HPP #define ALG ...
- STL学习笔记--算法
关于STL算法需要注意的是: (1) 所有STL算法被设计用来处理一个或多个迭代器区间.第一个区间通常以起点和终点表示,至于其他区间,多数情况下只需提供起点即可,其终点可自动以第一区间的元素数推导出来 ...
- STL学习笔记(算法概述)
算法头文件 要运用C++标准程序库的算法,首先必须包含头文件<algorithm> 使用STL算法时,经常需要用到仿函数以及函数配接器.它们定义域<functional>头文件 ...
- C++ STL 已序区间查找算法
#include <iostream>#include <algorithm>#include <list>#include <functional># ...
- Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据
Effective STL 学习笔记 Item 34: 了解哪些算法希望输入有序数据 */--> div.org-src-container { font-size: 85%; font-fam ...
- Effective STL 学习笔记 Item 30: 保证目标区间足够大
Effective STL 学习笔记 Item 30: 保证目标区间足够大 */--> div.org-src-container { font-size: 85%; font-family: ...
- Effective STL 学习笔记: Item 22 ~ 24
Effective STL 学习笔记: Item 22 ~ 24 */--> div.org-src-container { font-size: 85%; font-family: monos ...
随机推荐
- 关于js无法设置input的value的问题
html内容来自: <script type="text/html" id="theTemplate"> <input id="in ...
- 在ros下使用tf
tf真是一个好东西,把坐标变换都简化了 首先tf需要有一个broadcaster #include <ros/ros.h> #include <tf/transform_broadc ...
- EXCEL匹配结果match并跳转链接hyperlink
1,有时候想要搜索另一个表格中含有相同内容的项,然后跳转到搜索结果单元. 需要用到两个函数,MATCH和HYPERLINK 2,A表格如下 B表格如下 3,在B2单元格中输入函数 =HYPERLINK ...
- 计蒜客 18487.Divisions-大数的所有因子个数-Miller_Rabin+Pollard_rho-超快的(大数质因解+因子个数求解公式) (German Collegiate Programming Contest 2015 ACM-ICPC Asia Training League 暑假第一阶段第三场 F)
这一场两个和大数有关的题目,都用到了米勒拉宾算法,有点东西,备忘一下. 题目传送门 F. Divisions 传送门 这个题是求一个数的所有因子个数,但是数据比较大,1e18,所以是大数的题目,正常的 ...
- HDU 2795.Billboard-完全版线段树(区间求最值的位置、区间染色、贴海报)
HDU2795.Billboard 这个题的意思就是在一块h*w的板子上贴公告,公告的规格为1*wi ,张贴的时候尽量往上,同一高度尽量靠左,求第n个公告贴的位置所在的行数,如果没有合适的位置贴则输出 ...
- MySQL索引,如何正确创建MySQL索引?
索引可以提高数据的检索效率,也可以降低数据库的IO成本,并且索引还可以降低数据库的排序成本.排序分组操作主要消耗的就是CPU资源和内存,所以能够在排序分组操作中好好的利用索引将会极大地降低CPU资源的 ...
- ife2015-task2-javascript-util.js
util.js/** * Created by Administrator on 2016/12/14. *///判断是否为数组function isArray(arr){ return (arr i ...
- MongoDB 聚合Group(一)
原文:http://blog.csdn.net/congcong68/article/details/45012717 一.简介 db.collection.group()使用JavaScript,它 ...
- Sync 攻击原理及防范技术
据统计,在所有黑客攻击事件中,SYN攻击是最常见又最容易被利用的一种攻击手法.相信很多人还记得2000年YAHOO网站遭受的攻击事例,当时黑客利用的就是简单而有效的SYN攻击,有些网络蠕虫病毒配合SY ...
- 使用MySQL正则表达式 __MySQL必知必会
正则表达式作用是匹配方本,将一个模式(正则表达式)与一个文本串进行比较. MySQL用WHERE子句对正则表达式提供了初步的支持,允许你指定用正则表达式过滤SELECT检索出的数据. MySQL仅支持 ...