剑指 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;
    }
};
相关推荐
koping_wu13 小时前
【leetcode】排序数组:快速排序、堆排序、归并排序
java·算法·leetcode
小O的算法实验室14 小时前
2025年AEI SCI1区TOP,基于自适应进化算法的城市空中交通多目标枢纽选址,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
历程里程碑14 小时前
LeetCode 283:原地移动零的优雅解法
java·c语言·开发语言·数据结构·c++·算法·leetcode
星火飞码iFlyCode14 小时前
iFlyCode实践规范驱动开发(SDD):招考平台报名相片质量抽检功能开发实战
java·前端·python·算法·ai编程·科大讯飞
leaves falling14 小时前
c语言-根据输入的年份和月份,计算并输出该月份的天数
c语言·开发语言·算法
jghhh0114 小时前
锥束CT(CBCT)三维重构算法:FDK算法详解与实现
线性代数·算法·重构
世界唯一最大变量14 小时前
此算法能稳定求出柏林52城问题最优解7540.23(整数时为7538),比传统旅行商问题的算法7544.37还优
前端·python·算法
元亓亓亓14 小时前
LeetCode热题100--139. 单词拆分--中等
算法·leetcode·职场和发展
Eloudy14 小时前
通过示例看 C++ 函数对象、仿函数、operator( )
开发语言·c++·算法
释怀°Believe14 小时前
Daily算法刷题【面试经典150题-6️⃣kadane/】
算法·面试·职场和发展