[除自身以外数组的乘积]

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

    }
};

代码思路

采用左右乘积列表的方法,分为三个清晰步骤:

1. 初始化三个数组
cpp 复制代码
vector<int> l(nums.size(),1);  // 存储每个元素左侧所有元素的乘积
vector<int> r(nums.size(),1);  // 存储每个元素右侧所有元素的乘积
vector<int> ans(nums.size(),1); // 最终结果

l[i]:表示 nums[i] 左边所有元素 的乘积(初始为1)

r[i]:表示 nums[i] 右边所有元素的乘积(初始为1)

2. 计算左侧乘积(从左到右遍历)
cpp 复制代码
for(int i=1; i<nums.size(); i++) {
    l[i] = nums[i-1] * l[i-1];
}

逻辑

当前元素的左侧乘积 = 前一个元素的值 × 前一个元素的左侧乘积

例如:nums = [1,2,3,4]
l[0] = 1(初始值)
l[1] = nums[0] × l[0] = 1 × 1 = 1
l[2] = nums[1] × l[1] = 2 × 1 = 2
l[3] = nums[2] × l[2] = 3 × 2 = 6

结果:l = [1, 1, 2, 6]

3. 计算右侧乘积(从右到左遍历)
cpp 复制代码
for(int i=nums.size()-2; i>=0; i--) {
    r[i] = nums[i+1] * r[i+1];
}

逻辑

当前元素的右侧乘积 = 后一个元素的值 × 后一个元素的右侧乘积

继续以 nums = [1,2,3,4] 为例:
r[3] = 1(初始值)
r[2] = nums[3] × r[3] = 4 × 1 = 4
r[1] = nums[2] × r[2] = 3 × 4 = 12
r[0] = nums[1] × r[1] = 2 × 12 = 24

结果:r = [24, 12, 4, 1]

4. 合并左右乘积得到结果
cpp 复制代码
for(int i=0; i<nums.size(); i++) {
    ans[i] = l[i] * r[i];
}

逻辑

最终结果 = 左侧乘积 × 右侧乘积

继续示例:
ans[0] = l[0] × r[0] = 1 × 24 = 24
ans[1] = 1 × 12 = 12
ans[2] = 2 × 4 = 8
ans[3] = 6 × 1 = 6

结果:ans = [24, 12, 8, 6]

相关推荐
生成论实验室21 分钟前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星35 分钟前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿1 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨1 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
晨曦夜月2 小时前
map与unordered_map区别
算法·哈希算法
图码2 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
handler012 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
minglie13 小时前
实数列的常用递推模式
算法
代码小书生3 小时前
math,一个基础的 Python 库!
人工智能·python·算法
AI科技星3 小时前
全域数学·数术本源·高维代数卷(72分册)【乖乖数学】
人工智能·算法·数学建模·数据挖掘·量子计算