解题思路:
每次跳跃的距离尽可能长,则搬掉m块石头后,每两个石头间的距离都要大于等于ans
ans一定在区间[0,L]中,那么我们进行二分查找,如果满足条件需要搬掉的石头数大于m,则说明此时mid大于ans
如果满足条件需要搬掉的石头数量小于m,则说明mid小于ans
二分搜索mid会越来越接近答案,知道最后mid等于答案后left和right错开中止循环
代码:
#include<iostream>
#include<algorithm>
#include<stdio.h>
#include<cstring>
#include<queue>
#