首页 > 其他 > 详细

7.18每日一题题解

时间:2020-07-18 21:57:47      阅读:40      评论:0      收藏:0      [点我收藏+]

树上求和

涉及知识点:

  • 二分
  • 思维

solution:

  • 二分出答案
  • 假设答案是x的话,判断我们至少删除几个可以到达x
  • 如果我们需要删除的数量大于m的话,那么此时答案一定是比小的(right = mid - 1)
  • 否则x就有可能是答案(left = mid)

std:

#include <iostream>
#include <vector>
#include <algorithm>
#include <cstring>
using namespace std;
int n,m,l;
const int N = 5e4 + 10;
int a[N];

bool check(int x)
{
    int last = l;
    int cnt = 0;
    for(int i = n; i >= 0;i --)
    {
        if(last - a[i] < x){
            cnt ++; // 如果此时的距离比x小的话,那么这个就可以被删除
        }
        else{
            last = a[i]; // 更新最后一个石头
        }
    }
    
    if(cnt > m)return false;
    else return true;
    
}

int main()
{
    cin >> l >> n >> m;
    
    for(int i = 1;i <= n;i ++)
    {
        cin >> a[i];
    }
    
    int left = 0,right = l;
    
    while(left < right)
    {
        int mid = left + right + 1 >> 1;
        if(check(mid)){
            left = mid;
        }
        else{
            right = mid - 1;
        }
    }
    
    cout << left << endl;
    
    return 0;
}

7.18每日一题题解

原文:https://www.cnblogs.com/QFNU-ACM/p/13336751.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!