C++在有序序列中快速查找方法
cpp中的lower_bound()函数和upper_bound()函数就能解决这个问题,时间复杂度为O(logn).
代码如下:
#include <bits/stdc++.h>
using namespace std;
int a[6] = {1, 3, 5, 9, 14, 23};
int b[6] = {23, 14, 9, 5, 3, 1};
bool cmp(const int& a,const int& b){return a > b;}
int main() {
int i;
i = lower_bound(a, a+6, 3)-a;
cout<<“第一个大于等于3的数:”<<a[i]<<endl;
i = upper_bound(a, a+6, 3)-a;
cout<<“第一个大于3的数:”<<a[i]<<endl;
i = lower_bound(b, b+6, 3, cmp)-a;
cout<<“第一个小于等于3的数:”<<a[i]<<endl;
i = upper_bound(b, b+6, 3, cmp)-a;
cout<<“第一个小于3的数:”<<a[i]<<endl;
i = lower_bound(b, b+6, 3, greater<int>())-a;
cout<<“第一个小于等于3的数:”<<a[i]<<endl;
i = upper_bound(b, b+6, 3, greater<int>())-a;
cout<<“第一个小于3的数:”<<a[i]<<endl;
return 0;
}
结果:
第一个大于等于3的数:3
第一个大于3的数:5
第一个小于等于3的数:3
第一个小于3的数:1
第一个小于等于3的数:3
第一个小于3的数:1
欢迎使用66资源网
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
7. 本站有不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别!
66源码网 » C++在有序序列中快速查找方法
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 如遇到加密压缩包,请使用WINRAR解压,如遇到无法解压的请联系管理员!
7. 本站有不少源码未能详细测试(解密),不能分辨部分源码是病毒还是误报,所以没有进行任何修改,大家使用前请进行甄别!
66源码网 » C++在有序序列中快速查找方法