C++ STL之查找算法
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之查找算法的更多相关文章
- C++ STL 常用查找算法
C++ STL 常用查找算法 adjacent_find() 在iterator对标识元素范围内,查找一对相邻重复元素,找到则返回指向这对元素的第一个元素的迭代器.否则返回past-the-end. ...
- STL常用查找算法介绍
adjacent_find() 在iterator对标识元素范围内,查找一对相邻重复元素,找到则返回指向这对元素的第一个元素的迭代器.否则返回past-the-end. #include <io ...
- STL中的查找算法
STL中有很多算法,这些算法可以用到一个或多个STL容器(因为STL的一个设计思想是将算法和容器进行分离),也可以用到非容器序列比如数组中.众多算法中,查找算法是应用最为普遍的一类. 单个元素查找 1 ...
- 常用的STL查找算法
常用的STL查找算法 <effective STL>中有句忠告,尽量用算法替代手写循环:查找少不了循环遍历,在这里总结下常用的STL查找算法: 查找有三种,即点线面: 点就是查找目标为单个 ...
- [Data Structure & Algorithm] 七大查找算法
查找是在大量的信息中寻找一个特定的信息元素,在计算机应用中,查找是常用的基本运算,例如编译程序中符号表的查找.本文简单概括性的介绍了常见的七种查找算法,说是七种,其实二分查找.插值查找以及斐波那契查找 ...
- 七大查找算法(附C语言代码实现)
来自:Poll的笔记 - 博客园 链接:http://www.cnblogs.com/maybe2030/p/4715035.html 阅读目录 1.顺序查找 2.二分查找 3.插值查找 4.斐波那契 ...
- stl非变易算法(二)
这里接着上篇stl非变易算法(一)进行总结.主要解析算法函数count.count_if.mismatch.equal.search.search_n以及find_end.给出算法函数的实现及測试用例 ...
- STL非变易算法 - STL算法
欢迎访问我的新博客:http://www.milkcu.com/blog/ 原文地址:http://www.milkcu.com/blog/archives/1394600460.html 原创:ST ...
- 查找算法(Java实现)
1.二分查找算法 package other; public class BinarySearch { /* * 循环实现二分查找算法arr 已排好序的数组x 需要查找的数-1 无法查到数据 */ p ...
随机推荐
- 注册微信小程序
注册微信小程序 小程序是一种新的开放能力,可以在微信内被便捷地获取和传播,同时具有出色的使用体验.开发者可以根据平台提供的能力,快速地开发一个小程序. 开放内容包括: 开放注册范围:企业.政府.媒体. ...
- 团队博客作业Week1 Team Homework #3软件工程在北航
这次我们采访了一位大四的学姐,让她简单地谈了谈去年学习软件工程的经历和感受. 在完成软件工程大作业的过程中,由于计划安排与实际脱节,导致时间前松后紧,平均每周花在这门课上的时间大约有8个小时. 项目完 ...
- 数据库SQLiteDatabase
package com.baclock.entity; import android.provider.BaseColumns; /** * Created by Jack on 5/4/2016. ...
- javascript_22_for_二维数组
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8&quo ...
- 用户 IIS APPPOOL\DefaultAppPool 登录失败的解决方法
解决方案 1.先查看你的网站使用的是哪个应用程序池 2.设置应用程序池的选项 3.标识选项 选LocalSystem或NetworkService就可以解决问题
- PAT-乙级-1048. 数字加密(20)
1048. 数字加密(20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 CHEN, Yue 本题要求实现一种数字加密方法.首先固 ...
- window.open被IE拦截的解决办法
由于在使用window.open时,在很多情况下,弹出的窗口会被浏览器阻止,但若是使用a链接target='_blank',则不会,基于这一特点,自己封装了一个open方法: function ope ...
- PHP之Error与Logging函数讲解
PHP Error 和 Logging 简介 error 和 logging 函数允许你对错误进行处理和记录. error 函数允许用户定义错误处理规则,并修改记录错误的方式. logging 函数允 ...
- hdu 4324 Triangle LOVE(拓扑排序,基础)
题目 /***************************参考自****************************/ http://www.cnblogs.com/newpanderking ...
- TCP/IP协议栈与数据包封装+TCP与UDP区别
ISO制定的OSI参考模型的过于庞大.复杂招致了许多批评.与此对照,由技术人员自己开发的TCP/IP协议栈获得了更为广泛的应用.如图2-1所示,是TCP/IP参考模型和OSI参考模型的对比示意图. T ...