C++STL有好几种查找算法,但是他们的用法上有很多共同的地方:

1、除了binary_search的返回值是bool之外(查找的了返回true,否则返回false),其他所有的查找算法返回值都是一个迭代器(查找成功返回目标所在迭代器的位置,否则返回最后一个元素的后一个位置或者说是容器的end())

2、查找算法经常会用到迭代器区间,注意区间是前闭后开的

3、所有查找函数中如果存在两个区间,第一个区间是被查找对象的区间,第二个是目标对象的区间,如果只有一个区间则是被查找对象的区间。

4、对于有序查找的3个函数,一定要事先排序,否则可能直接返回查找不到,不要与真的不存在该元素混淆掉

分类:

查找单个元素find、find_if

查找子区间 search、search_n、find_end,其中find_end和search功能一样,只不过是从后往前查找

搜索子区间中的一个值find_first_of

有序区间的查找算法binary_search,lower_bound,upper_bound,注意这类查找一定要有序,否则返回错误

 #include<iostream>
#include<algorithm>
using namespace std;
int main()
{
//查找操作经常会用到迭代器区间,一定要注意前闭后开,找不到的时候就返回最后一个位置
//输入参数是一个迭代器区间和要查找的值,如果查找成功返回第一个目标值的迭代器位置,查找失败返回区间所在的最后位置的后一个
//注意:迭代器区间是前闭后开的,如迭代区间为[1,100),那么查找下标为1-99对应的值,如果查找失败则返回100下标对应的迭代器
int num[]={,,,,,,,};
//*******查找单个元素find、find_if********************************//
//_InIt find(_InIt _First, _InIt _Last, const _Ty& _Val)
//这里偷个小懒,没有使用STL中的容器和迭代器,而是使用数组和指针代替了
int *p;
p=find(num,num+,);
if((p-num)>)
{
cout<<"没有这个值"<<endl;
}
else
{
cout<<"第一个7所在的下标是"<<p-num<<endl;
} p=find(num,num+,);
if((p-num)>)
{
cout<<"没有这个值"<<endl;
}
else
{
cout<<"第一个3所在的下标是"<<p-num<<endl;
} //find_if需要使用到绑定器和STL中的函数对象,这里先不写程序了 //******************查找子区间 search、search_n、find_end**********************//
//_FwdIt1 search(_FwdIt1 _First1, _FwdIt1 _Last1,_FwdIt2 _First2, _FwdIt2 _Last2)
int num1[]={,,};
p=search(num,num+,num1,num1+);
if((p-num)>)
{
cout<<"没有这个区间的数"<<endl;
}
else
{
cout<<"第一个num1所在num中下标是"<<p-num<<endl;
}
//find_end和search一样,只不过是从后往前查
p=find_end(num,num+,num1,num1+);
if((p-num)>)
{
cout<<"没有这个区间的数"<<endl;
}
else
{
cout<<"最后一个num1所在num中下标是"<<p-num<<endl;
} //find_end和search一样,只不过是从后往前查 //search_n查找具有相同的n个值的位置
//_FwdIt1 search_n(_FwdIt1 _First1, _FwdIt1 _Last1,_Diff2 _Count, const _Ty& _Val)
int num2[]={,,,,,,,,,};
p=search_n(num2,num2+,,);
if((p-num2)>)
{
cout<<"没有这个区间的数"<<endl;
}
else
{
cout<<"第一个符合条件的目标所在num中下标是"<<p-num2<<endl;
} //******************搜索子区间中的一个值find_first_of**********************//
//find_first_of
//_FwdIt1 find_first_of(_FwdIt1 _First1, _FwdIt1 _Last1,_FwdIt2 _First2, _FwdIt2 _Last2, _Pr _Pred)
int fnum1[]={,,,,,,,,,};
int fnum2[]={,,,,,};
p=find_first_of(fnum1,fnum1+,fnum2,fnum2+);
if((p-fnum1)>)
{
cout<<"没有匹配的值"<<endl;
}
else
{
cout<<"第一个符合条件的目标所在fnum1中下标是"<<p-fnum1<<endl;
} //******************有序区间的查找算法binary_search,lower_bound,upper_bound**********************//
//binary_search
//bool binary_search(_FwdIt _First, _FwdIt _Last, const _Ty& _Val)
//注意二分查找返回值是bool类型,
//只能判断要查找的元素在不在所在区间,不能返回位置,根据其原理,因为他是跳跃式查找,没法确定哪一个是第一次出现的目标
int bnum[]={,,,,,,,,};
cout<<binary_search(bnum,bnum+,);
//upper_bound查找第一个比目标大的值,返回所在位置的迭代器
//_FwdIt upper_bound(_FwdIt _First, _FwdIt _Last, const _Ty& _Val)
p=upper_bound(bnum,bnum+,);
if((p-bnum)>)
{
cout<<"没有匹配的值"<<endl;
}
else
{
cout<<"第一个符合条件的目标所在bnum中下标是"<<p-bnum<<endl;
}
//lower_bound查找第一个比目标小的值,返回所在位置的迭代器
return ;
}

C++ STL之查找算法的更多相关文章

  1. C++ STL 常用查找算法

    C++ STL 常用查找算法 adjacent_find() 在iterator对标识元素范围内,查找一对相邻重复元素,找到则返回指向这对元素的第一个元素的迭代器.否则返回past-the-end. ...

  2. STL常用查找算法介绍

    adjacent_find() 在iterator对标识元素范围内,查找一对相邻重复元素,找到则返回指向这对元素的第一个元素的迭代器.否则返回past-the-end. #include <io ...

  3. STL中的查找算法

    STL中有很多算法,这些算法可以用到一个或多个STL容器(因为STL的一个设计思想是将算法和容器进行分离),也可以用到非容器序列比如数组中.众多算法中,查找算法是应用最为普遍的一类. 单个元素查找 1 ...

  4. 常用的STL查找算法

    常用的STL查找算法 <effective STL>中有句忠告,尽量用算法替代手写循环:查找少不了循环遍历,在这里总结下常用的STL查找算法: 查找有三种,即点线面: 点就是查找目标为单个 ...

  5. [Data Structure & Algorithm] 七大查找算法

    查找是在大量的信息中寻找一个特定的信息元素,在计算机应用中,查找是常用的基本运算,例如编译程序中符号表的查找.本文简单概括性的介绍了常见的七种查找算法,说是七种,其实二分查找.插值查找以及斐波那契查找 ...

  6. 七大查找算法(附C语言代码实现)

    来自:Poll的笔记 - 博客园 链接:http://www.cnblogs.com/maybe2030/p/4715035.html 阅读目录 1.顺序查找 2.二分查找 3.插值查找 4.斐波那契 ...

  7. stl非变易算法(二)

    这里接着上篇stl非变易算法(一)进行总结.主要解析算法函数count.count_if.mismatch.equal.search.search_n以及find_end.给出算法函数的实现及測试用例 ...

  8. STL非变易算法 - STL算法

    欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/1394600460.html 原创:ST ...

  9. 查找算法(Java实现)

    1.二分查找算法 package other; public class BinarySearch { /* * 循环实现二分查找算法arr 已排好序的数组x 需要查找的数-1 无法查到数据 */ p ...

随机推荐

  1. jQuery 单选按钮切换

    html代码片段一: <div class="row"> <div class="col-sm-12"> <label for=& ...

  2. Java架构师之路:JAVA程序员必看的15本书

    作为Java程序员来说,最痛苦的事情莫过于可以选择的范围太广,可以读的书太多,往往容易无所适从.我想就我自己读过的技术书籍中挑选出来一些,按照学习的先后顺序,推荐给大家,特别是那些想不断提高自己技术水 ...

  3. 【狼窝乀野狼】Serializer妙手回春

    在我们很多程序中,需要将数据保存到本地,以便于下次打开还能看到原始数据.例如我们Xmind思维导图,例如我们的Power Designer等等,都是有保存一个隶属于自己的工程文件,那么今天我要说的就是 ...

  4. JavaWeb常见错误总结

    错误1:(Ajax未加载问题) 今天我在学习AJAX的时候,想从一个JS文件中引入JQuery,然后在这个JS文件中使用AJAX的方法.结果V8引擎一直报错,错误类型是Uncaught Referen ...

  5. UI控件tag属性和魔法数字的处理

    说明:tag属性有很大的用处,它就好像每个UI控件的id,当多个按钮指向同一个监听方法时,可以给方法带参数UIButton,然后根据不同的tag值 来判断执行哪个按钮的监听事件: - (IBActio ...

  6. angular事件代理

    在angular中,是不支持事件代理的,有些时候,我们需要处理比较多的数据,尤其是一些列表的时候,可能会很多,如果给每一项都加事件的话,注定慢很多,为了解决这个事情,因此需要一个做事件代理的direc ...

  7. [转载]C#中字典集合的两种遍历

    Dictionary<string, string> dictionary = new Dictionary<string,string>(); foreach (string ...

  8. javax.mail.MessagingException: 501 Syntax: HELO hostname Linux端异常解决

    在项目里面使用javamail在window环境正常,放在服务器上面的时候抛出异常javax.mail.MessagingException: 501 Syntax: HELO hostname ,原 ...

  9. Memcache安全配置

    Memcache安全配置 瞌睡龙 · 2014/01/20 17:59 0x00 Memcache简介 Memcache是一个高性能的分布式的内存对象缓存系统,通过在内存里维护一个统一的巨大的hash ...

  10. linux故障救援

    今天手贱,误操作将/usr/lib整个文件夹都删了.但是系统内还有很多重要的文件和数据,不敢贸然重装系统. 弄了个u盘启动. 一开始整个系统只有一个分区,原系统装在这个分区里,我用u盘启动后,用分区管 ...