Codeforces Round 973 (Div. 2) - D题

传送门:Problem - D - Codeforces

题目大意:

思路:

尽量要 最大值变小,最小值变大

即求 最大值的最小 和 最小值的最大 -> 二分答案

AC代码:

代码有注释

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define int long long
void solve()
{
    int n; cin >> n;
    vector<int> a(n + 1), b(n + 1);
    for (int i = 1; i <= n; i++) cin >> a[i];
    auto check1 = [&](int limit)
        {
            // limit 此时就是 最大值的最小值
            // 经过操作后,若 b[i] <= limit 就是ok的,否则就放弃这个值
            // 最大值最小
            for (int i = 1; i <= n; i++) b[i] = a[i];
            for (int i = 1; i < n; i++)
            {
                // b[i] 超过 limit ,就要减小 b[i]
                if (b[i] > limit)
                {
                    b[i + 1] += (b[i] - limit);
                    b[i] = limit;
                }
            }
            for (int i = 1; i <= n; i++)
            {
                if (b[i] > limit) return false;
            }
            return true;
        };
    int left = 0; int right = 1e12;
    while (right > left)
    {
        int mid = left + right >> 1;
        if (check1(mid))right = mid;
        else left = mid + 1;
    }
    int ans = left;
    auto check2 = [&](int limit)
        {
            // 最小值最大
            // limit 就是最小值的最大值
            for (int i = 1; i <= n; i++) b[i] = a[i];
            for (int i = 1; i < n; i++)
            {
             
                if (b[i] > limit)
                {
                    b[i + 1] += (b[i] - limit);
                    b[i] = limit;
                }
            }
            int mn = 2e18;
            for (int i = 1; i <= n; i++) mn = min(mn, b[i]);
            // 经过操作后,mn 仍大于 limit ,则可以继续增大limit
            if (mn >= limit)return true;
            else return false;
        };
    left = 0; right = 1e12;
    while (right > left)
    {
        int mid = left + right + 1 >> 1;
        if (check2(mid))left = mid;
        else right = mid - 1;
    }
    cout << ans - left << endl;
}
signed main()
{
    int tt; cin >> tt;
    while (tt--)solve();
    return 0;
}
相关推荐
AI工程架构师2 小时前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法
不想写代码的星星2 小时前
C++继承、组合、聚合:选错了是屎山,选对了是神器
c++
祈安_2 小时前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
归去_来兮16 小时前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
千寻girling1 天前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
颜酱1 天前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
不想写代码的星星1 天前
std::function 详解:用法、原理与现代 C++ 最佳实践
c++
CoovallyAIHub2 天前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
NineData2 天前
数据库管理工具NineData,一年进化成为数万+开发者的首选数据库工具?
运维·数据结构·数据库
木心月转码ing2 天前
Hot100-Day14-T33搜索旋转排序数组
算法