C++之前缀和

今天来学习一下前缀和

老样子,只是原理和基础题

前缀和的做法如下:

当想要求一个数组某个区间的和,但是直接暴力超时的话可以考虑前缀和

先来看这道题:

B3612 【深进1.例1】求区间和 - 洛谷

看一下数据,n,m均可以为1e5,暴力的时间复杂度就是O(1e10),绝对超时,这时候前缀和就派上用场了

我们可以记数组a,s,a[i]里存输入的数,s[i]里存的就是a数组前i位的和

由此,我们可以写出一个赋值语句:

s[i]=s[i-1]+a[i];

再反过来看题目,却发现题目让求区间[l,r]之间的和,有些人就蒙了,大家再想想有没有什么办法呢?

很好,我们可以拿s[r]-s[l-1],就能得到这个区间之间的总和

因为s[r]记录了前r个数的总和,s[l-1]记录了前l-1个数的总和,两者相减便是答案

假设a=1,3,6,7,9,13,16,8;l=3;r=7

这时,s=1,4,10,17,26,39,55,63

我们拿s[r](55)-s[l-1](4)便是要求的值51了

所以这道题的代码也就不难了

#include <bits/stdc++.h>
using namespace std;
int n,m;
int num[1000010],S[1000010];
signed main(){
	cin>>n;
	for(int i=1;i<=n;i++){
		cin>>num[i];
		S[i]=S[i-1]+num[i];
	}
	cin>>m;
	while(m--){
		int l,r;
		cin>>l>>r;
		cout<<S[r]-S[l-1]<<"\n";
	}
	return 0;
}

完结撒花

内容概要:本文围绕并网与离网模式下的风光互补制氢合成氨系统,开展容量配置与调度优化的建模与仿真研究,基于Python代码实现核心技术复现。研究聚焦于风能与太阳能发电的波动性特征,结合电解水制氢及氢气合成氨的能量转换环节,构建综合能源系统的多目标优化模型,兼顾经济性、能源利用率与系统稳定性。通过引入先进的优化算法与Cplex等求解工具,对系统关键设备容量进行优化配置,并实现多时段运行调度的精细化决策,推动可再生能源高效转化为绿色化工产品,为“电-氢-氨”一体化系统的设计与运行提供科学依据和技术支撑。; 适合人群:具备一定Python编程能力和优化建模基础,从事新能源系统、氢能利用、综合能源系统规划与运行等方向研究的科研人员、高校研究生及工程技术人员。; 使用场景及目标:①用于风光制氢合成氨系统的容量规划、运行策略制定与经济性评估;②支撑高水平学术论文的模型复现、算法验证与创新研究,提升对多能互补系统协同优化机制的理解与实践能力; 阅读建议:建议结合Cplex等优化求解器运行代码,深入理解模型构建过程中的目标函数设计与约束条件表达,重点关注可再生能源出力不确定性处理与能量转换效率建模,并参考相关文献进一步拓展优化算法与场景分析维度。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值