剑指 Offer 66. 构建乘积数组

给定一个数组 A[0,1,...,n-1],请构建一个数组 B[0,1,...,n-1],其中 B[i] 的值是数组 A 中除了下标 i 以外的元素的积, 即 B[i]=A[0]×A[1]×...×A[i-1]×A[i+1]×...×A[n-1]。不能使用除法。

示例:

复制代码
输入: [1,2,3,4,5]
输出: [120,60,40,30,24]

提示:

  • 所有元素乘积之和不会溢出 32 位整数
  • a.length <= 100000

解答

cpp 复制代码
class Solution {
public:
    vector<int> constructArr(vector<int>& a) {
        int len = a.size();
        if(!len) return a;
        vector<int> res(len, 1);
        int tmp = 1;

        // 本次循环后,res[i]为下标为i左边的数的乘积
        for(int i = 1; i < len; ++i)
        {
            res[i] = res[i - 1] * a[i - 1];
        }

        for(int i = len - 2; i >= 0; --i)
        {
            tmp *= a[i + 1]; // 计算出下标i右边的数的乘积
            res[i] *= tmp;
        }
        return res;
    }
};
相关推荐
有意义14 小时前
深度拆解分割等和子集:一维DP数组与倒序遍历的本质
前端·算法·面试
用户7268761033715 小时前
解放双手的健身助手:基于 Rokid AR 眼镜的运动计时应用
算法
Wect15 小时前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
ZhengEnCi1 天前
08c. 检索算法与策略-混合检索
后端·python·算法
程序员小崔日记1 天前
大三备战考研 + 找实习:我整理了 20 道必会的时间复杂度题(建议收藏)
算法·408·计算机考研
lizhongxuan2 天前
AI小镇 - 涌现
算法·架构
AI工程架构师2 天前
通常说算力是多少 FLOPS,怎么理解,GPU和CPU为什么差异这么大
算法
祈安_2 天前
Java实现循环队列、栈实现队列、队列实现栈
java·数据结构·算法
归去_来兮2 天前
拉格朗日插值算法原理及简单示例
算法·数据分析·拉格朗日插值
千寻girling2 天前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法