优选算法——前缀和(3):寻找数组的中心下标

🔥近津薪荼: 个人主页 🎬个人专栏: 《近津薪荼的算法日记》 《Linux操作系统及网络基础知识分享》 《c++基础知识详解》 《c语言基础知识详解》 ✨"百分百死亡率的人生,你还在犹豫什么,犹豫怎么死吗?"


1.上期参考代码

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

int main() {
   int n,m,q,x1,x2,y1,y2;
   cin >>n>>m>>q;
   vector<vector<int>> arr(n+1,vector<int>(m+1,0));
   for (int i=1;i<n+1;i++)
   {
    for(int j=1;j<m+1;j++)
    {
        cin>>arr[i][j];
    }
   }
   vector<vector<long long >> dp(n+1,vector<long long>(m+1,0));
    for (int i=1;i<n+1;i++)
     {
       for(int j=1;j<m+1;j++)
        {
            dp[i][j]=dp[i-1][j]+dp[i][j-1]-dp[i-1][j-1]+arr[i][j];
        }
     }//创建dp数组
     while(q--)
     {
        cin >>x1>>y1>>x2>>y2;
        cout <<dp[x2][y2]-dp[x2][y1-1]-dp[x1-1][y2]+dp[x1-1][y1-1]<<endl;
     }
}

2.本期知识点导图

3.本期要讲解的题目是

寻找数组的中心下标

要点:

  • 中心下标:下标指向的元素不算,下标左边所有元素之和与右边所有元素之和相等
  • 边界情况

4.解题

4.1 暴力解法:

遍历数组,i为分割下标,分别计算下标左边和右边的元素之和,相等,则下标i就是中心下标,返回即可,找不到返回-1。

时间复杂度O(N2

4.2优解

这道题目还是求连续区区间的和 ,可以考虑使用前缀和

将前缀和数组创建好之后,将**dpi-1与dpn-dpi**做比较即可。

一维前缀和的递推公式也是老生常谈了,这边就不打了。注意这里的前缀和数组是要求到所有元素的和的。

这题的特殊之处在于,我们不仅可以使用前缀和,也可以使用"后缀和"

求出两个dp数组:front和back,最终比较fronti与backi是否相等即可。

注意:两个dp数组的长度都是n。要求的是前i-1或者后n-i个元素的和,和上边的

下边就要求两个dp数组的求和递推公式了,front和上边的前缀和方法的递推公式一样,back就要处理一下,但是逻辑也是一样,的大家自己求哈。

代码逻辑

  • 创建前后缀和数组
  • 用公式初始化
  • 比较front i 与back i 是否相等

5.下期要讲解的题目是:

除了自身以外数组的乘积

6.嗟食

如果小编写的内容对佬有帮助,还请大佬点点三连加关注哦
佬的支持就是我前进的最大动力 ~
期待与佬的再次相遇~

相关推荐
小羊在睡觉2 小时前
力扣84. 柱状图中最大的矩形
后端·算法·leetcode·golang·go
3DVisionary2 小时前
蓝光三维扫描:医疗制造的精度焦虑怎么解
人工智能·算法·制造·蓝光三维扫描·医疗制造·三维检测·义齿检测
好评笔记2 小时前
机器学习面试八股——常用损失函数
人工智能·深度学习·算法·机器学习·校招
weixin_468466853 小时前
全局与局部注意力机制新手实战指南
人工智能·python·深度学习·算法·自然语言处理·transformer·注意力机制
_日拱一卒3 小时前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM3 小时前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro4 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort4 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域5 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
QiLinkOS6 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法