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

1.DP34 一维前缀和

2.题目描述:

3.解法(前缀和):

算法思路:

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

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

b.使用前缀和数组快速求出某个区间内元素的和:当询问[l,r]时:区间内所有元素的和为sum[r]-sum[l-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;
}
相关推荐
匠心网络科技几秒前
前端学习手册-JavaScript条件判断语句全解析(十八)
开发语言·前端·javascript·学习·ecmascript
神仙别闹几秒前
基于C++生成树思想的迷宫生成算法
开发语言·c++·算法
海上彼尚几秒前
Go之路 - 1.gomod指令
开发语言·后端·golang
我命由我123451 分钟前
Java 开发使用 MyBatis PostgreSQL 问题:使用了特殊字符而没有正确转义
java·开发语言·数据库·postgresql·java-ee·mybatis·学习方法
C语言小火车3 分钟前
红黑树(C/C++ 实现版)—— 用 “带配重的书架” 讲透本质
c语言·开发语言·c++·红黑树
阿里嘎多学长4 分钟前
2025-12-10 GitHub 热点项目精选
开发语言·程序员·github·代码托管
snow123f9 分钟前
Lambda 表达式怎么用
java·开发语言·线程
梓䈑10 分钟前
【C++】C++11(右值引用和移动语义、可变参数模板 和 包装器)
java·开发语言·c++
好评12411 分钟前
【C++】一篇吃透容器适配器三件套:从stack/queue/priority_queue到deque底层
c++·stl·queue·stack
CoovallyAIHub11 分钟前
南京理工大学联手百度、商汤科技等团队推出Artemis:用结构化视觉推理革新多模态感知
深度学习·算法·计算机视觉