【C++算法】1.【模板】前缀和

1.DP34 一维前缀和

2.题目描述:

3.解法(前缀和):

算法思路:

a.先预处理一个前缀和数组:

用sumi表示:1,i区间内所有元素的和,那么sumi-1里面存的就是1,i-1区间内所有元素的和。那么可得递推公式sumi=sumi-1+arri。l-1

b.使用前缀和数组快速求出某个区间内元素的和:当询问l,r时:区间内所有元素的和为sumr-suml-1

4.代码
cpp 复制代码
#include <iostream>
#include <ostream>
#include <vector>
using namespace std;

int main()
{
    //1.读入数据
    int n,q;
    cin>>n>>q;
    vector<int> arr(n+1);
    for(int i=1;i<=n;i++) cin>>arr[i];
    //2.预处理
    vector<long long> dp(n+1);//防止溢出
    for(int i=1;i<=n;i++) dp[i]=dp[i-1]+arr[i];
    //3.使用前缀和数组
    int l=0,r=0;
    while(q--)
    {
        cin>>l>>r;
        cout<<dp[r]-dp[l-1]<<endl;
    }


    return 0;
}
相关推荐
未若君雅裁13 小时前
JVM 垃圾回收器全景与G1深度解析
java·开发语言·jvm
霸道流氓气质13 小时前
Java 大数据量异步处理方案:线程池 vs 消息队列
java·开发语言
devilnumber13 小时前
想真正吃透 + 灵活运用 Java 代理模式
java·开发语言·代理模式
为何创造硅基生物13 小时前
C++ 独占指针被销毁后,堆也会自己销毁
c++
AC赳赳老秦13 小时前
OpenClaw 助力技术面试:自动生成面试题、模拟面试、整理面试知识点
开发语言·python·面试·职场和发展·自动化·deepseek·openclaw
刘科领13 小时前
修改jdk 第一步: 仓库以及构建(jdk17)
java·开发语言
C+-C资深大佬13 小时前
C++ 中的 constexpr与 const区
java·开发语言·c++
8Qi813 小时前
LeetCode 4:寻找两个正序数组的中位数 —— 二分查找法
java·算法·leetcode·职场和发展·二分查找
仙俊红13 小时前
Java 单例模式:类里面为什么可以有自己类型的字段?
java·开发语言·单例模式
8Qi813 小时前
LeetCode 32:最长有效括号 —— 栈 + 标记法 题解
java·数据结构·算法·leetcode·职场和发展··括号匹配