前缀和的另外一种用法,前缀和分解

对于前缀和都熟悉了,其实前缀和有另外一种用法,即分解前缀和,典型的就是这个题目:

238. 除了自身以外数组的乘积238. 除了自身以外数组的乘积

对于这个题目,由于我们不能用除法,那么我们用数组来记录避免重复相乘就很重要了,那么问题在于我们如何去存储呢,yaoxiangyiduanshijian(不难想到),我们其实要做的就是除了这个数,前面的乘积乘以后面的乘积,那么是不是就需要两个数组,当然一个也可以,先搞两个直观一点,一个记录前i个不包括i的乘积,一个记录后i个不包括i的乘积,那么结果就出来了

当然我们可以从后(从前也行)遍历,首先记录pre数组,即i前面的乘积,然后记录suf等于1,suf就是专门记录从后面往前面的算的后i个乘积,第num.size()-1个开始就是suf*pre,然后suf更新乘等于numi,继续这么循环下去直到i=0,最后返回pre就行了

cpp 复制代码
class Solution {
public:
    vector<int> productExceptSelf(vector<int>& nums) {
        int n=nums.size();
        vector<int>pre(n,1);
        for(int i=1;i<n;i++)
        {
            pre[i]=pre[i-1]*nums[i-1];
        }

        int suf=1;
        for(int i=n-1;i>=0;i--)
        {   
            pre[i]*=suf;
            suf*=nums[i];
        }
        
        return pre;
    }
};
相关推荐
88号技师1 小时前
2026年2月一区SCI-交叉传播优化算法Propagation Alongside Crossover-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
悠仁さん1 小时前
数据结构 图(代码实现篇 C语言版)
数据结构·算法·图论
aini_lovee1 小时前
多智能体粒子群优化(Multi-Agent Particle Swarm Optimization, MAPSO)
算法
周末也要写八哥1 小时前
贪心法求经典算法题——最低加油次数
算法
插件开发1 小时前
vs2015 cuda c++ 线程号的计算详解
开发语言·c++·算法
有点。1 小时前
C++(前缀和与差分)
c++·算法
仍然.2 小时前
算法题目---BFS解决最短路问题
算法·宽度优先
渡众机器人2 小时前
第八届全球校园人工智能算法精英大赛-算法应用赛-空地协同侦排挑战赛规则
人工智能·算法
wayz112 小时前
Overlap:HWMA(Holt-Winter移动平均线)技术指标详解
算法·金融·数据分析·量化交易·特征工程