社区讨论
虽然过了但是有点不懂啊啊啊啊啊啊啊啊啊啊啊啊
P2678[NOIP 2015 提高组] 跳石头参与者 2已保存回复 3
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 3 条
- 当前快照
- 1 份
- 快照标识符
- @mi6hin9k
- 此快照首次捕获于
- 2025/11/20 04:58 4 个月前
- 此快照最后确认于
- 2025/11/20 04:58 4 个月前
代码中我写了问题
CPP#include<cstdio>
using namespace std;
int ans,l,m,n,rock[50005];
int check(int ch){
int last=0;
int cnt=0;
for(int i=1;i<n;i++){
if(rock[i]-last<ch)
cnt++;
else last=rock[i];
if(cnt>m) return 0;
}
return 1;
}
int main(){
scanf("%d%d%d",&l,&n,&m);
for(int a=1;a<=n;a++)
scanf("%d",&rock[a]);
rock[++n]=l;
int le=1,ri=l;
while(le<=ri){ //紫书上是用的le<ri,下面的ri=mid,但是我改成那样就错
int mid=le+(ri-le)/2;
if(check(mid)) le=mid+1;
else ri=mid-1;
}
printf("%d",le-1);
}
回复
共 3 条回复,欢迎继续交流。
正在加载回复...