二分查找 左手的ㄟ右手 2021-09-21 17:12 319阅读 0赞 > ### 一、自己实现的 ### #include<iostream> #include<cstdio> #include<algorithm> using namespace std; int arr[100]; //二分查找 bool BinarySearch(int n, int target){ int left = 0; int right = n-1; while(left <= right){ int middle = left + (right - left) / 2; if(arr[middle] < target){ left = middle+1; }else if(arr[middle] > target){ right = middle - 1; }else{ return true; } } return false; } int main(){ int n; scanf("%d",&n); for(int i = 0; i < n; ++i){ scanf("%d",&arr[i]); } //二分查找必须是有序序列,所以在查找之前要排序 sort(arr,arr+n); int m; scanf("%d",&m); for(int i = 0;i < m; ++i){ int target; scanf("%d",&target); if(BinarySearch(n,target)){ printf("YES\n"); }else{ printf("NO\n"); } } return 0; } > ### 二、系统自带的 ### c++内置二分查找 \#include < algorithm > **一、binary\_search:查找某个元素是否出现。** 函数模板: binary\_search(arr\[\], arr\[\]+size, target) 参数说明: arr\[\]: 数组首地址 size:数组元素个数 target:需要查找的值 函数功能: 在数组中以二分法检索的方式查找,若在数组(要求数组元素非递减)中查找到indx元素则真,若查找不到则返回值为假。 **二、lower\_bound:查找第一个大于或等于某个元素的位置。** 函数模板: lower\_bound(arr\[\],arr\[\]+size ,target) 参数说明: arr\[\]: 数组首地址 size:数组元素个数 target:需要查找的值 函数功能: 函数lower\_bound()在first和last中的前闭后开区间进行二分查找,返回大于或等于val的第一个元素位置(注意是地址)。如果所有元素都小于val,则返回last的位置 **注意:**函数lower\_bound()在first和last中的前闭后开区间进行二分查找,返回大于或等于val的第一个元素位置。如果所有元素都小于val,则返回last的位置,且last的位置是越界的!值为n. 返回查找元素的第一个可安插位置,也就是“元素值>=查找值”的第一个元素的位置 **三、upper\_bound:查找第一个大于某个元素的位置。** 函数模板: upper\_bound(arr\[\],arr\[\]+size , target) 参数说明: arr\[\]: 数组首地址 size:数组元素个数 target:需要查找的值 函数功能:函数upper\_bound()返回的在前闭后开区间查找的关键字的上界,返回大于val的第一个元素位置 例如:一个数组number序列1,2,2,4.upper\_bound(2)后,返回的位置是3(下标)也就是4所在的位置,同样,如果插入元素大于数组中全部元素,返回的是last。(注意:数组下标越界) 返回查找元素的最后一个可安插位置,也就是==“元素值>查找值”==的第一个元素的位置 。 #include<iostream> #include<cstdio> #include<algorithm> using namespace std; int arr[100]; int main(){ int n; scanf("%d",&n); for(int i = 0; i < n; ++i){ scanf("%d",&arr[i]); } //二分查找必须是有序序列,所以在查找之前要排序 sort(arr,arr+n); int m; scanf("%d",&m); for(int i = 0;i < m; ++i){ int target; scanf("%d",&target); //lower_bound获取的是地址值 int position = lower_bound(arr,arr + n,target)-arr; if(position != n && arr[position == target]){ printf("YES\n"); }else{ printf("NO\n"); } } return 0; }
相关 二分查找 函数lower\_bound()在first和last中的前闭后开区间进行二分查找,返回大于或等于val的第一个元素位置。如果所有元素都小于val,则返回last的位置 举例 约定不等于承诺〃/ 2022年08月07日 14:47/ 0 赞/ 60 阅读
相关 二分查找 二分查找可以说是在经典不过的查找算法了,比如JAVA的库函数里,就有相应的代码实例。如下写出两个版本的二分查找,非递归和递归的 非递归的 public int bi 系统管理员/ 2022年08月06日 16:24/ 0 赞/ 77 阅读
相关 二分查找 //二分查找 /\ 递归算法 int searchB1(int A\[\], int low, int high, int data); 非递归算法 int 绝地灬酷狼/ 2022年05月12日 01:40/ 0 赞/ 68 阅读
相关 查找——二分查找 基本思想 二分查找是建立在有序顺序表基础上的!步骤如下: 1. 将表中间位置记录的关键字与给定K值进行比较,若两者相等,则查找成功。 2. 蔚落/ 2022年03月27日 03:46/ 0 赞/ 406 阅读
相关 二分查找 二分查找(先排序) typedef struct LNode List; struct LNode{ ElemenType Data[MAXSIZ 爱被打了一巴掌/ 2022年02月02日 17:13/ 0 赞/ 150 阅读
相关 二分查找 使用递归的版本 def bin_search(lst, num, start=None, end=None): """ 二分查找 àì夳堔傛蜴生んèń/ 2022年01月07日 04:03/ 0 赞/ 126 阅读
相关 二分查找 int search2( int array\[\], int n, int v) \{ int left, right, middle; 心已赠人/ 2021年12月20日 16:07/ 0 赞/ 151 阅读
相关 二分查找 二分查找 二分查找是一个比较简单的算法,用 C++ 语言实现如下: template <typename T> int binary_search( ゞ 浴缸里的玫瑰/ 2021年12月13日 03:57/ 0 赞/ 217 阅读
相关 二分查找 > 一、自己实现的 include<iostream> include<cstdio> include<algorithm> u 左手的ㄟ右手/ 2021年09月21日 17:12/ 0 赞/ 320 阅读
还没有评论,来说两句吧...