二分答案----

二分答案 - 题目详情 - HydroOJ

问题描述

给定一个由n个数构成的序列a,你可以进行k次操作,每次操作可以选择一个数字,将其+1,问k次操作以后,希望序列里面的最小值最大。问这个值是多少。

输入格式

第一行输入两个正整数n,k。(1≤n≤105,1≤k≤1013)

第二行输入n个正整数,表示序列a。(1≤ai​≤106)

输出格式

输出最大的最小值

样例输入

5 10

1 4 2 6 8

Copy

样例输出

5

Copy

思路:

枚举最小值的最大值,然后判断是否可以成功,也就是使用操作次数是否在k范围内。

代码:

复制代码
#include <bits/stdc++.h>
using namespace std;
typedef long long ll; 
const ll N = 1e5 + 10;
ll n, k;
ll a[N];

bool check(ll mid, ll k) 
{
    ll sum = 0;
    for (ll i = 1; i <= n; i++) 
	{
        if (a[i] < mid) 
		{
            sum += mid - a[i];
        }
    }
    return sum <= k;
}

int main() {
    cin >> n >> k;
    ll min_val = LLONG_MAX;
    for (ll i = 1; i <= n; i++) 
	{
        cin >> a[i];
        min_val = min(min_val, a[i]);
    }
    sort(a + 1, a + n + 1);
    ll l = min_val, r = 1e6 + k;
    while (l + 1 != r) 
	{
        ll mid = (l + r) / 2;
        if (check(mid, k)) 
		{
            l = mid;
        } 
		else 
		{
            r = mid;
        }
    }
    cout << l;
    return 0;
}    
相关推荐
不知天地为何吴女士1 小时前
Day32| 509. 斐波那契数、70. 爬楼梯、746. 使用最小花费爬楼梯
算法
小坏坏的大世界1 小时前
C++ STL常用容器总结(vector, deque, list, map, set)
c++·算法
励志要当大牛的小白菜4 小时前
ART配对软件使用
开发语言·c++·qt·算法
qq_513970444 小时前
力扣 hot100 Day56
算法·leetcode
PAK向日葵5 小时前
【算法导论】如何攻克一道Hard难度的LeetCode题?以「寻找两个正序数组的中位数」为例
c++·算法·面试
爱喝矿泉水的猛男7 小时前
非定长滑动窗口(持续更新)
算法·leetcode·职场和发展
YuTaoShao7 小时前
【LeetCode 热题 100】131. 分割回文串——回溯
java·算法·leetcode·深度优先
YouQian7728 小时前
Traffic Lights set的使用
算法
go54631584659 小时前
基于深度学习的食管癌右喉返神经旁淋巴结预测系统研究
图像处理·人工智能·深度学习·神经网络·算法
aramae9 小时前
大话数据结构之<队列>
c语言·开发语言·数据结构·算法