16.求数组除了当前元素的所有乘积

1.题目描述

示例 1:

复制代码
输入: nums = [1,2,3,4]
输出: [24,12,8,6]

示例 2:

复制代码
输入: nums = [-1,1,0,-3,3]
输出: [0,0,9,0,0]

2.解题思路

思路1:(0要单独处理)

1)第一次循环算出所有元素的乘积all

2)第二次循环遍历每个元素,算出all/numsi并加入结果数组res

思路2:(不用除法)

1)第一次循环从前往后循环(index从1到size -1),算出numsi左边的所有元素乘积,保存到left数组中

2)第二次循环从后往前循环(index从size-2到0),算出numsi右边的所有元素乘积,保存到right数组中

3)从前往后算,index从0到size-1,每次都计算resi = lefti * righti,返回res即可

3.代码

cpp 复制代码
  vector<int> productExceptSelf(vector<int>& nums) {
        int size=nums.size();
        if(size==0){
            return {};
        }
        
        vector<int> left(size);
        vector<int> right(size);
        vector<int> res(size);
        left[0] = 1;
        right[size-1]=1;
//先算nums[i]的左边所有元素的乘积,从前往后算
        for(int i =1; i<=size -1 ;i++  ){
            left[i] = left[i-1] * nums[i-1];
        }
        //算nums[i]的右边所有乘积,从后往前算
        for(int j = size -2;j>=0;j--){
            right[j] = right[j+1]*nums[j+1];
        }
        //开始计算nums[i]左边乘积 乘以  右边乘积
        for(int i = 0;i<=size-1;i++){
            res[i] = left[i]*right[i];
        }
        return res;
    }
相关推荐
sheeta19984 分钟前
LeetCode 每日一题笔记 日期:2026.05.29 题目:3300. 最小元素
笔记·leetcode
_日拱一卒5 分钟前
LeetCode:994腐烂的橘子
java·数据结构·算法·leetcode·深度优先
珂朵莉MM36 分钟前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--束搜索
人工智能·算法
Omics Pro1 小时前
首个!外源天然产物综合性代谢图谱
数据库·人工智能·算法·机器学习·r语言
voidmort1 小时前
3. 微调(Fine-tuning)与强化学习(RL)的核心思想
python·深度学习·算法
人道领域2 小时前
【LeetCode刷题日记】669.修剪二叉搜索树
开发语言·python·算法
QiLinkOS3 小时前
【从实验室到商业战场:发明专利如何重塑科技与企业的共生生态】
大数据·c语言·数据结构·c++·人工智能·单片机·算法
小白兔奶糖ovo4 小时前
【Leetcode】231. 2的幂
linux·算法·leetcode
xiaoxiaoxiaolll4 小时前
《Light: Science & Applications》合并BIC实现80倍阈值单模运行:超紧凑光子晶体激光器新突破
人工智能·算法·机器学习
Peter·Pan爱编程4 小时前
14. Lambda 表达式:随手可写的函数对象
c++·算法·ai编程