二分查找、二分答案

本文介绍了二分查找算法在整数和浮点数上的实现,以及如何判断题目是否适合使用二分法。重点讨论了二分查找在求最大值最小和最小值最大问题中的策略,并提到了STL库中的lower_bound和upper_bound函数在不同排序顺序下的应用。
摘要由CSDN通过智能技术生成

#include<iostream>
using namespace std;

//二分

//板子

//整数二分
//
//向左找

int j = 1, k = n;
while (j < k) {
    int mid = j + k >> 1;
    if (check(mid))k = mid;
    else j = mid + 1;
}

//向右找

int j = 1.k = n;
while (j < k) {
    int mid = j + k + 1 >> 1;
    if (check(mid))j = mid;
    else k = mid - 1;
}

//浮点二分

int j = 1; int k = n;
while (j - k > 1e-5) {
    if (check(mid))k = mid;//j=mid;
    else j = mid;//k=mid;
}


//二分答案
如何判断一个题是不是用二分答案做的呢 ?

1、答案在一个区间内(一般情况下,区间会很大,暴力超时)
2、直接搜索不好搜,但是容易判断一个答案可行不可行
3、该区间对题目具有单调性,即:在区间中的值越大或越小,题目中的某个量对应增加或减少。

此外,可能还会有一个典型的特征:求...最大值的最小 、 求...最小值的最大。
1、求...最大值的最小,我们二分答案(即二分最大值)的时候,判断条件满足后,尽量让答案往前来(即:让r = mid),对应模板1;
2、同样,求...最小值的最大时,我们二分答案(即二分最小值)的时候,判断条件满足后,尽量让答案往后走(即:让l = mid),对应模板2;


//stl库
upper_bound(begin, end, value)
在从小到大的排好序的数组中,在数组的[begin, end) 区间中二分查找第一个大于value的数,找到返回该数字的地址,没找到则返回end。

lower_bound(begin, end, value)
在从小到大的排好序的数组中,在数组的[begin, end) 区间中二分查找第一个大于等于value的数,找到返回该数字的地址,没找到则返回end。


 use  greater<type>()

upper_bound(begin, end, value, greater<int>())
在从大到小的排好序的数组中,在数组的[begin, end) 区间中二分查找第一个小于value的数,找到返回该数字的地址,没找到则返回end。

lower_bound(begin, end, value, greater<int>())
在从大到小的排好序的数组中,在数组的[begin, end) 区间中二分查找第一个小于等于value的数,找到返回该数字的地址,没找到则返回end。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值