分析
y总刚刚讲的二分,所以本蒟蒻就使用二分实现啦,左右边界分别是$l=0,r=maxH$。题目说如果$H(k+1)>E$,那么机器人就失去$H(k+1)-E$的能量值,否则它将得到$E-H(k+1)$的能量值,那我们就可以写一个$success$函数,其中判断条件就是任何一步的能量值都不能小于$0$,如果小于$0$就返回$false$,如果其中有任何一步使得能量大于最大高度返回$true$,否则就返回$false$。
C++ 代码
#include <iostream>
#include <cstdio>
using namespace std;
int n;
int maxH = -1;
int h[100005];
bool success(int x)
{
int temp = x;
for (int i = 1; i <= n; i++)
{
temp += temp - h[i];
if (temp < 0) return false;
if (temp >= maxH) return true;
}
return true;
}
int main()
{
scanf("%d", &n);
for (int i = 1; i <= n; i++)
{
scanf("%d", &h[i]);
maxH = max(maxH, h[i]);
}
int l = 0, r = maxH;
while (l < r)
{
int mid = l + r >> 1;
if (success(mid))
{
r = mid;
}
else
{
l = mid + 1;
}
}
printf("%d\n", l);
return 0;
}
感谢,看了你代码之后思路清晰了许多。
请问 maxH 这个变量的具体含义是什么
二分边界的最大值,就是题目输入的h最大值
题目不是要求输出能量值吗。为什么要用高度作为二分查找的范围条件
这里有点不明白,求解求解
最高的话需要的能量也是最大的,要求最小能通过的能量就是从1到maxh之间寻找,因为如果能量都比最高的高的话就会是一直增加的,不会是递减的
为什么把h数组按照升序排好再二分,答案就有问题
每一步能量变为2E - h,对于一个初始能量他之后的每一步能量都是确定的,排序之后求得就不是原来问题的解了
orz
评论的解释终于解决我的疑问。。。。
lz, 为什么 if (temp >= maxH) return true; 大于maxH的话 要return true呢
能量已经比最大的都大了,后面就不会衰减了,直接返回,不返回可能一直加甚至溢出为负然后就错了
可以
哇,改了半天看你的解释懂了,谢谢哈
请问success函数里,为什么还要判一下temp>=maxH呢?
懂了,因为能量值只增不减,所以很快就爆int甚至long long,变成负数
对的哈哈哈。当时我因为这个问题还卡住了。