二分mid的取法

Posted buhuiflydepig

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二分mid的取法相关的知识,希望对你有一定的参考价值。

二分的两种形式:

1、范围缩小时,r = mid,l = mid + 1,取中间值时,mid = (l + r) >> 1.

2、范围缩小时,l = mid,r = mid - 1,取中间值时,mid = (l + r + 1) >> 1;

 

总而言之,正确写出二分的流程是:

1、通过分析具体问题,确定左右半段哪一个是可行区间,以及 mid 归属哪一半段。

2、根据分析结果,选择“r = mid, l = mid + 1, mid = (l + r) >> 1” 和“l = mid, r= mid - 1, mid = (l + r + 1) >> 1”两个配套形式之一。

3、二分的终止条件是 l == r,该值就是答案所在位置。

以上是关于二分mid的取法的主要内容,如果未能解决你的问题,请参考以下文章

POJ 3061 Subsequence (二分||尺取法)

POJ 3061 Subsequence ( 二分 || 尺取法 )

Codeforces 1156C 尺取法 / 二分

题解报告:poj 3061 Subsequence(二分前缀法or尺取法)

hihocoder-1483区间价值 (二分+尺取法)

51nod-1686 第K大区间(二分+尺取法)