面试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                   # 返回最终结果
相关推荐
GGBondlctrl4 分钟前
【leetcode】字符串,链表的进位加法与乘法
算法·leetcode·链表·字符串相加·链表相加·字符串相乘
打野二师兄1 小时前
LeetCode经典题解:21、合并两个有序链表
算法·leetcode·链表
小赵小赵福星高照~1 小时前
iOS UI视图面试相关
ui·ios·面试
前端拿破轮1 小时前
腾讯面试官:听说你在字节面试用栈实现队列,那怎么用队列实现栈呢?
算法·leetcode·面试
mrsk3 小时前
每天一个小知识点,DRY究竟是什么?
前端·面试·代码规范
小程序华东同舟求职3 小时前
Ampace厦门新能安科技Verify 测评演绎数字推理及四色测评考点分析、SHL真题题库
人工智能·经验分享·科技·面试·职场和发展·求职招聘
张先shen4 小时前
Redis的高可用性与集群架构
java·redis·面试·架构
银之夏雪丶4 小时前
this你了解多少呢
前端·javascript·面试
Hilaku4 小时前
写了8年代码,我发现决定你薪水的,往往不是技术
前端·面试·掘金技术征文
轻语呢喃4 小时前
useContext : hook中跨层级通信的优雅方案
javascript·react.js·面试