当前位置: 首页 > news >正文

二分答案----

二分答案 - 题目详情 - 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;
}    

http://www.dtcms.com/a/126199.html

相关文章:

  • BeautifulSoup 踩坑笔记:SVG 显示异常的真正原因
  • unity曲线射击
  • Vuex 源码
  • 13. Git 远程仓库配置
  • rocketmq 5 TopicMessageType validate failed
  • 反垄断合规时代来临:企业如何抢占合规管理先机?
  • 谷歌最近放出大招——推出全新“Agent Development Kit(简称ADK)
  • YOLO学习笔记 | 一文详解YOLOv11核心创新与实践方法
  • 管理、切换多个 hosts工具之SwitchHosts
  • csdn的文章一键迁移搬家到博客园
  • centos-LLM-生物信息-BioGPT-使用1
  • VLC快速制作rtsp流媒体服务器
  • 数字人:打破次元壁,从娱乐舞台迈向教育新课堂(4/10)
  • Python实现批量插入PostgreSQL数据库的脚本分享
  • JAVA入门-Collection单列集合体系
  • Java学习手册:面向对象编程核心概念
  • TypeScript对不同种变量怎么声明不同类型
  • mongodb--用户管理
  • swift菜鸟教程13(函数)
  • Wincc脚本全部不运行
  • MySQL死锁问题深度剖析与Java解决方案
  • 解决react仿deepseek流式对话出现重复问题
  • JS String类型函数
  • 3dmax的python通过普通的摄像头动捕表情
  • 健康与好身体笔记
  • 项目学习总结001
  • 《算法笔记》3.3小节——入门模拟->图形输出
  • Android学习总结之OKHttp拦截器和缓存
  • 【leetcode hot 100 152】乘积最大子数组
  • OpenCV图像形态学详解