5711. 有界数组中指定下标处的最大值

本文介绍了一种利用二分查找解决特定序列问题的方法。针对一个由正整数组成的长度为n的序列,该序列中相邻元素之差不超过1,并且序列总和不超过maxSum的条件下,如何找到序列中最大值。文章详细解释了二分查找的过程及其应用,并给出了具体的实现代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

思路

首先很容易想到,答案具有单调性。
所以做法就是二分答案
当前a[index]=mid的时候,如果整个序列总和小于等于maxSum,那么如果a[index]<mid的时候也一定满足。
那么我们就尝试增大一下mid,如果满足增大下限,不满足则减小上限。

根据题目条件,注意两点
1.都是正整数
2.相邻两个差值最多为1

那么我们知道当前a[index]=mid,就是尽可能让这个位置为最值点,其他位置尽量小。
我们去计算左边部分,左边可以放index+1个数字(包括第index这个位置)
那么其实就是往左边一直递减放就可以了。
如果减到了1,因为要为正整数,剩下位置也还是都是1就行。

右边也是同理计算。

代码

class Solution {
public:
    int maxValue(int n, int index, int maxSum) {
            int L=index+1,R=n-index;
            int l=0,r=1e9+1;
            while(l+1<r){
                int mid=l+r>>1;
                long long ans=0;
                if(L>=mid) ans+=1ll*mid*(mid+1)/2+L-mid;//能放的个数≥mid  剩下位置放1
                else ans+=1ll*L*(mid+mid-L+1)/2;//减不到1,即求[mid-L+1,mid]这个区间的和
                //下面右部分同理
                if(R>=mid) ans+=1ll*mid*(mid+1)/2+R-mid;
                else ans+=1ll*R*(mid+mid-R+1)/2;
                ans-=mid;
                if(ans<=maxSum) l=mid;
                else r=mid;

            }
        return l;
    }
};
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

我不会c语言

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值