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

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

思路

首先很容易想到,答案具有单调性。
所以做法就是二分答案
当前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;
    }
};
【论文复现】一种基于价格弹性矩阵的居民峰谷分时电价激励策略【需求响应】(Matlab代码实现)内容概要:本文介绍了一种基于价格弹性矩阵的居民峰谷分时电价激励策略,旨在通过需求响应机制优化电力系统的负荷分布。该研究利用Matlab进行代码实现,构建了居民用电行为与电价变动之间的价格弹性模型,通过分析不同时间段电价调整对用户用电习惯的影响,设计合理的峰谷电价方案,引导用户错峰用电,从而实现电网负荷的削峰填谷,提升电力系统运行效率与稳定性。文中详细阐述了价格弹性矩阵的构建方法、优化目标函数的设计以及求解算法的实现过程,并通过仿真验证了所提策略的有效性。; 适合人群:具备一定电力系统基础知识和Matlab编程能力,从事需求响应、电价机制研究或智能电网优化等相关领域的科研人员及研究生。; 使用场景及目标:①研究居民用电行为对电价变化的响应特性;②设计并仿真基于价格弹性矩阵的峰谷分时电价激励策略;③实现需求响应下的电力负荷优化调度;④为电力公司制定科学合理的电价政策提供理论支持和技术工具。; 阅读建议:建议读者结合提供的Matlab代码进行实践操作,深入理解价格弹性建模与优化求解过程,同时可参考文中方法拓展至其他需求响应场景,如工业用户、商业楼宇等,进一步提升研究的广度与深度。
针对TC275微控制器平台,基于AUTOSAR标准的引导加载程序实现方案 本方案详细阐述了一种专为英飞凌TC275系列微控制器设计的引导加载系统。该系统严格遵循汽车开放系统架构(AUTOSAR)规范进行开发,旨在实现可靠的应用程序刷写与启动管理功能。 核心设计严格遵循AUTOSAR分层软件架构。基础软件模块(BSW)的配置与管理完全符合标准要求,确保了与不同AUTOSAR兼容工具链及软件组件的无缝集成。引导加载程序本身作为独立的软件实体,实现了与上层应用软件的完全解耦,其功能涵盖启动阶段的硬件初始化、完整性校验、程序跳转逻辑以及通过指定通信接口(如CAN或以太网)接收和验证新软件数据包。 在具体实现层面,工程代码重点理了TC275芯片特有的多核架构与内存映射机制。代码包含了对所有必要外设驱动(如Flash存储器驱动、通信控制器驱动)的初始化与抽象层封装,并设计了严谨的故障安全机制与回滚策略,以确保在软件更新过程中出现意外中断时,系统能够恢复到已知的稳定状态。整个引导流程的设计充分考虑了时序确定性、资源占用优化以及功能安全相关需求,为汽车电子控制单元的固件维护与升级提供了符合行业标准的底层支持。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
答案: 1.构造随机数组: #include <stdio.h> #include <stdlib.h> #include <time.h> int main() { int n, i, j, temp, flag; int arr[100]; srand((int)time(NULL)); //用系统时间初始化rand()函数 printf("请输入n的值:"); scanf("%d", &n); for (i = 0; i < n; i++) { flag = 1; temp = rand() % 100 + 1; //生成1-100内的随机数 for (j = 0; j < i; j++) { if (arr[j] == temp) { //如果与已生成的元素重复,重新生成 flag = 0; break; } } if (flag) { arr[i] = temp; } else { i--; } } printf("生成的随机数组为:\n"); for (i = 0; i < n; i++) { printf("%d ", arr[i]); } printf("\n"); return 0; } 2.使用指针法输出数组元素值: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 4, 5}; int* p; for (p = arr; p < arr + 5; p++) { printf("%d ", *p); } printf("\n"); return 0; } 3.数组中所有偶数求和: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 4, 5}; int n = sizeof(arr) / sizeof(arr[0]); int i, sum = 0; for (i = 0; i < n; i++) { if (arr[i] % 2 == 0) { sum += arr[i]; } } printf("所有偶数的和为%d\n", sum); return 0; } 4.数组中所有奇数求和: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 4, 5}; int n = sizeof(arr) / sizeof(arr[0]); int i, sum = 0; for (i = 0; i < n; i++) { if (arr[i] % 2 == 1) { sum += arr[i]; } } printf("所有奇数的和为%d\n", sum); return 0; } 5.数组中的所有数扩大k倍: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 4, 5}; int n = sizeof(arr) / sizeof(arr[0]); int i, k; printf("请输入k的值:"); scanf("%d", &k); for (i = 0; i < n; i++) { arr[i] *= k; } printf("扩大%d倍后的数组为:\n", k); for (i = 0; i < n; i++) { printf("%d ", arr[i]); } printf("\n"); return 0; } 6.数组中所有偶数位置的元素加起来: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 4, 5}; int n = sizeof(arr) / sizeof(arr[0]); int i, sum = 0; for (i = 0; i < n; i += 2) { if (arr[i] % 2 == 0) { sum += arr[i]; } } printf("偶数位置的元素加起来为%d\n", sum); return 0; } 7.找出数组中的最大值: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 4, 5}; int n = sizeof(arr) / sizeof(arr[0]); int i, max = arr[0]; for (i = 1; i < n; i++) { if (arr[i] > max) { max = arr[i]; } } printf("数组中的最大值为%d\n", max); return 0; } 8.找出数组中的最小值: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 4, 5}; int n = sizeof(arr) / sizeof(arr[0]); int i, min = arr[0]; for (i = 1; i < n; i++) { if (arr[i] < min) { min = arr[i]; } } printf("数组中的最小值为%d\n", min); return 0; } 9.n在数组中搜索指定元素,看其是否存在: #include <stdio.h> int main() { int arr[] = {1, 2, 3, 4, 5}; int n = sizeof(arr) / sizeof(arr[0]); int i, x; printf("请输入要搜索的元素:"); scanf("%d", &x); for (i = 0; i < n; i++) { if (arr[i] == x) { printf("%d存在于数组中\n", x); return 0; } } printf("%d不存在于数组中\n", x); return 0; }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

我不会c语言

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

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

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

打赏作者

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

抵扣说明:

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

余额充值