zoukankan      html  css  js  c++  java
  • 跳石头深悉

    #include<stdio.h>
    #include<algorithm>
    using namespace std;
    int m,n;
    long long l,map[50015],left,right,mid;
    int main()
    {
    scanf("%lld %d %d",&l,&n,&m);
    //if(n==0||m==0) {printf("%lld
    ",l);return 0;}
    for(int i=1;i<=n;i++)
        scanf("%lld",&map[i]);
    map[n+1]=l;
    left=0;
    right=l;
    while(left<=right)//可以等于,left=3,right=4时,mid=3,再进行一次后mid=4 
        mid=(left+right)/2;
        printf("mid=%lld
    ",mid);
        int move=0,h=0;
        for(int i=1;i<=n+1;i++)
            {
             if(map[i]-h<mid)move++;
             else h=map[i];
            }
        if(move<=m) //如果发现石块刚好满足也要再往后找一找啊。。。万一下个也可以  
          { left=mid+1;printf("left1=%lld
    ",left);}
           
        else {
            right=mid-1;
            printf("right1=%lld
    ",right);
            }    
        printf("left=%lld
    ",left);    
        printf("right=%lld
    ",right);
    }
    printf("%lld",left-1); //为什么不输出left——因为看上面left=mid+1,而你二分的是mid---跳跃长度,显然left+1后并没有保证满足条件(下一个万一只更改了right就跳出呢?)
        return 0;
    }
  • 相关阅读:
    reids 持久化
    center os 下redis安装以及基本使用
    MongoDB安装(Window)
    mysql中文乱码解决办法
    github托管代码
    MySQL表损坏修复【Incorrect key file for table】
    运维杂记-02
    配置ssh秘钥登陆
    nginx解决跨域问题
    运维杂记-01
  • 原文地址:https://www.cnblogs.com/voldemorte/p/7685074.html
Copyright © 2011-2022 走看看