二分答案 & 洛谷 P2678 跳石头
首先让我们先学一下二分答案这个东西...
二分答案,肯定与二分有关,还与可能是答案的东西有关...
二分答案的准确定义:
二分答案是指在答案具有单调性的前提下,利用二分的思想枚举答案,将求解问题转化为验证结果。
大体流程:
首先需要估计答案的上下界,然后不断取区间中点进行验证(这就要求答案的验证应当简单可行),并通过验证结果不断更新答案区间,最终得到答案。不难看出,朴素的枚举验证时间复杂度是O(n)的,而二分可以做到O(logn)
二分答案的特征:
1.答案具有单调性
2.二分答案的问题往往有固定的问法,比如:令最大值最小(最小值最大),求满足条件的最大(小)值等。
二分答案的写法:
1.在单调递增序列a中查找 >= x 的数中最小的一个(即x 或 x的后继):
while (l < r) {
int mid = (l + r) >> ;
if (a[mid] >= x) r = mid;
else l = mid + ;
}
return a[l];
后继
2.在单调递增序列a中查找 <= x 的数中最大的一个(即x 或 x的前驱):
while (l < r) {
int mid = (l + r + ) >> ;
if (a[mid] <= x) l = mid;
else r = mid - ;
}
return a[l];
前驱
关于这两段代码的解释(见下图):

下面这是一个二分答案的模板题(2019 pdoi T3):
https://www.luogu.org/problemnew/show/P2678
这是一个二分答案的模板,然后二分答案的题的细节实在是太多了!!!(然后就一直wa ,无法列举..
(在不知道有二分答案这个东西之前发现自己的思路完全与其相反,自己只是暴力地解出答案,而不是二分枚举答案
二分答案的核心上面也都讲了,下面直接是AC代码外加部分细节解释:
#include <cstdio>
inline int get_num(){
int num = ;
char c = getchar();
while (c < '' || c > '') c = getchar();
while (c >= '' && c <= '')
num = num * + c - '', c = getchar();
return num;
}//快读
const int maxn = 5e4 + ;
int stone[maxn], n, m, L;
inline int check(int x){
int cnt = , last = ;
for(int i = ; i <= n; i++){
if(stone[i] - stone[last] < x) cnt++;
//留着这块石头发现最短路径小于mid,则要删去
else last = i;//留着则更新上一块石头坐标
}
if(cnt <= m) return ;//是否合法
else return ;
}//检查是否合法
int main(){
L = get_num(), n = get_num(), m = get_num();
for(int i = ; i <= n; i++) stone[i] = get_num();
int l = , r = L;//@1
while(l < r){
int mid = (l + r + ) >> ;//@2
if(check(mid)) l = mid;
else r = mid - ;
}//二分答案的核心
printf("%d", l);
return ;
}
AC代码
解释:
@1:将r先设到不可能越界的一个位置,然后再进行二分,保证答案在[L,R]这个区间中
@2:>>1 和 / 2 都是除以二,但是 >> 1 是向下取整, / 2是向零取整,为了避免二分答案中出现负数。这行如果写成这种形式,那么r就直接赋值为L,不要赋值L+1
二分答案 & 洛谷 P2678 跳石头的更多相关文章
- [NOIP2015提高&洛谷P2678]跳石头 题解(二分答案)
[NOIP2015提高&洛谷P2678]跳石头 Description 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石.组委会已经选择好了两块岩石作为比赛起点和终点.在起点和终点之 ...
- 洛谷 P2678 跳石头
题目背景 一年一度的"跳石头"比赛又要开始了! 题目描述 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石.组委会已经选择好了两块岩石作为比赛起点和终点.在起点和终点之间 ...
- 洛谷 P2678 跳石头【经典二分答案/贪心】
题目描述 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石.组委会已经选择好了两块岩石作为比赛起点和终点.在起点和终点之间,有 NN 块岩石(不含起点和终点的岩石).在比赛过程中,选手们将从 ...
- [NOIP2015] 提高组 洛谷P2678 跳石头
题目背景 一年一度的“跳石头”比赛又要开始了! 题目描述 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石.组委会已经选择好了两块岩石作为比赛起点和终点.在起点和终点之间,有 N 块岩石(不 ...
- 洛谷P2678跳石头题解
题目 这个题也是一个很经典的题了.其主要思想也是二分答案,原因就是题目中只要出现最大值最小或最小值最大,这种描述十有八九就是二分答案. 这个题原题也是让我们求最短的跳跃距离的最大值. 显而易见,最大值 ...
- 【【洛谷P2678 跳石头】——%%%ShawnZhou大佬】
{dalao传送门} 这道题如果要使用暴力搜索直接求解会严重超时.实际上,我们可以发现,这个所谓的最短跳跃距离显然不能超过一个范围,而这个范围题目上已经给了出来.也就是说,答案是有一个确定的范围限制的 ...
- 洛谷P2678跳石头(提高)
题目背景 一年一度的“跳石头”比赛又要开始了! 题目描述 这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石.组委会已经选择好了两块岩石作为比赛起点和终点. 在起点和终点之间,有 N 块岩石( ...
- 洛谷 p2678 跳石头 题解
一道裸的二分答案 如果不会分治的去找dalao吧,本蒟蒻只会二分 不知道二分答案的看这里 这位dalao解释的很详细其实只是随便找了一个 那里面貌似也有这个题的题解,但我还是要写(才不是应付老师) 关 ...
- 洛谷P2678 跳石头
简简单单二分答案,n和m不要写反 Code: #include<cstdio> #include<algorithm> using namespace std; const i ...
随机推荐
- form表单中的button按钮
如果在form表单中 , 存在button元素,button元素就充当了submit的角色
- Pacemaker实现双机热备
在互联网高速发展的今天,尤其在电子商务的发展,要求服务器能够提供不间断服务.在电子商务中,如果服务器宕机,造成的损失是不可估量的.要保证服务器不间断服务,就需要对服务器实现冗余.在众多的实现服务器冗余 ...
- 证明3|n(n+1)(2n+1)
[证明3|n(n+1)(2n+1)] n(n+1)(2n+1) => n(n+1)(n+2+n-1) => n(n+1)(n+2) + n(n+1)(n-1) 因为n(n+1)(n+2). ...
- js如何解析后台传过来的json字符串
1.js如何解析后台传过来的json字符串? 注意:js是无法直接接收和使用json或者Php的数据,用的话会出现undefined,所以要转换一下. 方式一: var str = '{"r ...
- Arcgis engine编程报错查询(转)
Arcgis engine编程报错查询 标签: arcgis arcengine arcgisengine 2016年04月10日 17:29:35429人阅读 评论(0) 收藏 举报 分类: Ar ...
- Mock Server实践
转载自 https://tech.meituan.com/mock-server-in-action.html 背景 在美团服务端测试中,被测服务通常依赖于一系列的外部模块,被测服务与外部模块间通过R ...
- c语言实战 BJT时间转化位UTC时间
题目是这样的: 题目内容: UTC是世界协调时,BJT是北京时间,UTC时间相当于BJT减去8.现在,你的程序要读入一个整数,表示BJT的时和分.整数的个位和十位表示分,百位和千位表示小时.如果小时小 ...
- Java虚拟机学习总结之OutOfMemoryError异常
参考:深入理解java虚拟机一书 开始之前,我们也应当搞清楚连个概念,内存泄漏Memory Leak 内存溢出: 内存泄漏:程序中间动态分配了内存,但是在程序结束时没有释放内存,造成这部分内存不可用. ...
- Luogu 2704 [NOI2001]炮兵阵地
唔,想到了状压之后就不会了……实在是菜 考虑压两行,设$f_{i, j, k}$表示当前到第$i$行,上一行是$j$状态,前一行是$k$状态的最多能放的炮兵的数量. 发现第一维还可以滚掉,好像可以转移 ...
- Entity Framework在不同数据库下的配置
http://blog.csdn.net/weiky626/article/details/17068593 http://blog.csdn.net/niewq/article/details/41 ...