社区讨论

虽然过了但是有点不懂啊啊啊啊啊啊啊啊啊啊啊啊

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 条回复,欢迎继续交流。

正在加载回复...