面试150 除自身以外数组的乘积

思路

首先很容易想到暴力法:创建一个长度为n的结果数组,对于每个数以此下标进行划分,分别计算左右两边的乘积然后进行相乘。但是这个会超时!

因此需要优化,需要用前缀法进行优化。我们分别通过left去维护数组左侧的乘积去更新结果数组,然后在通过right去维护右侧的值的过程中,更新res并最后返回。

python 复制代码
from typing import List

class Solution:
    def productExceptSelf(self, nums: List[int]) -> List[int]:
        n = len(nums)                # 数组长度
        res = [1] * n                # 初始化结果数组,每个位置设为1(乘法单位)
        # 第一步:从左到右,计算每个位置左边所有数的乘积
        left = 1                     # 初始左乘积为1
        for i in range(n):
            res[i] = left            # 把左边的乘积放入结果中
            left *= nums[i]         # 更新左乘积,乘上当前nums[i]
           
        # 第二步:从右到左,再乘上右边所有数的乘积
        right = 1                    # 初始右乘积为1
        for i in range(n - 1, -1, -1):  # 从右向左遍历
            res[i] *= right          # 把右边的乘积乘到结果上
            right *= nums[i]         # 更新右乘积,乘上当前nums[i]
           
        return res                   # 返回最终结果
相关推荐
草履虫建模6 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
VT.馒头11 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
马猴烧酒.13 小时前
【面试八股|Java集合】Java集合常考面试题详解
java·开发语言·python·面试·八股
不穿格子的程序员15 小时前
从零开始写算法——普通数组篇:缺失的第一个正数
算法·leetcode·哈希算法
学历真的很重要15 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程管理(详解版)
学习·职场和发展·系统架构·系统架构师
闻哥17 小时前
从测试坏味道到优雅实践:打造高质量单元测试
java·面试·单元测试·log4j·springboot
VT.馒头17 小时前
【力扣】2722. 根据 ID 合并两个数组
javascript·算法·leetcode·职场和发展·typescript
执着25918 小时前
力扣hot100 - 108、将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
52Hz11819 小时前
力扣230.二叉搜索树中第k小的元素、199.二叉树的右视图、114.二叉树展开为链表
python·算法·leetcode