二分
c++中的内置二分函数:
1.binary_search:查找某个元素是否出现。
a.函数模板:binary_search(arr,arr+size ,indx)
b.参数说明:
arr: 数组首地址
size:数组元素个数
indx:需要查找的值
c.函数功能: 在数组中以二分法检索的方式查找,若在数组(要求数组元素非递减)中查找到indx元素则真,若查找不到则返回值为假。
2.lower_bound:查找第一个大于或等于某个元素的位置。
a.函数模板:lower_bound(arr,arr+size , indx):
b.参数说明:
arr: 数组首地址
size:数组元素个数
indx:需要查找的值
c.函数功能: 函数lower_bound()在first和last中的前闭后开区间进行二分查找,返回大于或等于val的第一个元素位置(注意是地址)。如果所有元素都小于val,则返回last的位置
d.注意:函数lower_bound()在first和last中的前闭后开区间进行二分查找,返回大于或等于val的第一个元素位置。如果所有元素都小于val,则返回last的位置,且last的位置是越界的!
3.upper_bound:查找第一个大于某个元素的位置。
a.函数模板:upper_bound(arr,arr+size , indx):
b.参数说明:
arr: 数组首地址
size:数组元素个数
indx:需要查找的值
c.函数功能:函数upper_bound()返回的在前闭后开区间查找的关键字的上界,返回大于val的第一个元素位置.
d.注意:如果插入元素大于数组中全部元素,返回的是last。(注意:数组下标越界)
模板:
其一:
1 #include <bits/stdc++.h> 2 using namespace std; 3 const int N=1e5; 4 int arr[N]; 5 int er_search(int l,int r){ 6 int mid; 7 while(l<r){ 8 mid=(l+r)>>1; 9 if(check()){ 10 r=mid; 11 } 12 else{ 13 l=mid+1; 14 } 15 } 16 return r; 17 } 18 int main(){ 19 int a,b; 20 er_search(a,b); 21 return 0; 22 }
其二:
1 #include <bits/stdc++.h> 2 using namespace std; 3 const int N=1e5; 4 int arr[N]; 5 int er_search(int l,int r){ 6 int mid; 7 while(l<r){ 8 mid=(l+r+1)>>1; 9 if(check(mid)){ 10 l=mid; 11 } 12 else{ 13 r=mid-1; 14 } 15 } 16 return l; 17 } 18 int main(){ 19 int a,b; 20 er_search(a,b); 21 return 0; 22 }
什么时候用到二分:
当能根据一个数与ans关系判断出ans所在的范围时使用。