当前位置: 首页 > news >正文

前缀和算法习题篇(上)

在这里插入图片描述

1.一维前缀和

题目描述:

在这里插入图片描述

解法一:暴力解法:模拟

时间复杂度是O(n*q),会超时。

解法二:前缀和解法:快速求出数组中某一个连续区间的和

快速是指O(1),前缀和思想可把时间复杂度可降到O(q)。

算法思路:
  1. 先预处理出来一个前缀和数组:O(n)
  • dp[i] 表示: [1, i] 区间内所有元素的和,那么 dp[i - 1] 里面存的就是 [1, i - 1] 区间内所有元素的和。
  • 递推公式: dp[i] = dp[i - 1] + arr[i] ;
  1. 使用前缀和数组,快速求出某一个区间内所有元素的和:O(q)
  • 当询问的区间是 [l, r] 时:区间内所有元素的和为: dp[r] - dp[l - 1] 。

时间复杂度为O(q)+O(n).

为什么我们的下标要从1开始计数呢?

举例:当访问的区间是[0,2]时,区间内所有元素的和为dp[2]-dp[-1],这里的dp[-1]越界。而当访问的区间是[1,2]时,区间内所有元素的和为dp[2]-dp[0],使dp[0]=0即可,不会越界。

  • 为了处理边界情况
  • 初始化:添加虚拟结点(辅助结点)
代码实现:
#include <iostream>
#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;
}

2.二维前缀和

题目描述:

在这里插入图片描述
在这里插入图片描述

解法一:暴力解法:模拟

时间复杂度是O(n* m *q),会超时。

解法二:前缀和解法

算法思路:

1.预处理出来一个前缀和矩阵: O(m*n)

  • dp[i][j]表示:从[1,1]位置到[i,j]位置,这段区间里面所有元素的和。

在这里插入图片描述

2.使用前缀和矩阵: O(q)
在这里插入图片描述

时间复杂度为O(m*n)+O(q).

代码实现:
#include <iostream>
#include<vector>
using namespace std;int main() 
{//1.读入数据int n=0,m=0,q=0;cin>>n>>m>>q;vector<vector<int>> arr(n+1,vector<int>(m+1));for(int i=1;i<=n;i++)for(int j=1;j<=m;j++)cin>>arr[i][j];//2.预处理前缀和矩阵vector<vector<long long>> dp(n+1,vector<long long>(m+1));//防止溢出for(int i=1;i<=n;i++)for(int j=1;j<=m;j++) dp[i][j]=dp[i-1][j]+dp[i][j-1]+arr[i][j]-dp[i-1][j-1];//3.使用前缀和矩阵int x1=0,y1=0,x2=0,y2=0;while (q--) {cin>>x1>>y1>>x2>>y2;cout<<dp[x2][y2]-dp[x1-1][y2]-dp[x2][y1-1]+dp[x1-1][y1-1]<<endl;} return 0;         
}

最后,本篇文章到此结束,感觉不错的友友们可以一键三连支持一下笔者,有任何问题欢迎在评论区留言哦~

http://www.lryc.cn/news/483585.html

相关文章:

  • C#核心(9)静态类和静态构造函数
  • B2002 Hello,World! C++实现
  • 前端-同源与跨域
  • MySQL远程连接错误解决:Host is not allowed to connect to this MySQL server
  • 详解C语言字符和字符串的输入与输出
  • adworld - stack2
  • Python学习从0到1 day28 Python 高阶技巧 ⑤ 多线程
  • nuget 管理全局包、缓存和临时文件夹
  • linux物理内存管理:node,zone,page
  • uniapp 设置安全区域
  • 渐进式JavaScript框架Vue 3 入门
  • 【真题笔记】21年系统架构设计师案例理论点总结
  • PostgreSQL的奥秘:深入探究事务与锁的秘密世界
  • Python进行GRPC和Dubbo协议的高级测试
  • 全程云OA系统QCPES.asmx存在SQL注入漏洞
  • 从建立TRUST到实现FAIR:可持续海洋经济的数据管理
  • 基于SSM的“汽车销售分析与管理系统”的设计与实现(源码+数据库+文档+PPT)
  • vs2015QT项目添加多语言翻译总结
  • 替换OpenTSDB和HBase,宝武集团使用IoTDB助力钢铁设备智能运维
  • MathGPT的原理介绍,在中小学数学教学的应用场景,以及代码样例实现
  • 前端框架大比拼:React.js, Vue.js 及 Angular 的优势与适用场景探讨
  • MySQL45讲 第二十讲 幻读是什么,幻读有什么问题?
  • MySQL技巧之跨服务器数据查询:进阶篇-从A数据库复制到B数据库的表中
  • 【论文阅读】利用SEM二维图像表征黏土矿物三维结构
  • 可靠UDP协议(KCP)使用说明
  • ffmpeg+D3D实现的MFC音视频播放器,支持录像、截图、音视频播放、码流信息显示等功能
  • 【Flink】-- flink新版本发布:v2.0-preview1
  • Node.js 版本管理的最终答案 Volta
  • 蓝桥杯每日真题 - 第11天
  • Vue vs React:两大前端框架的区别解析