【LeetCode最详尽解答】238.除自身以外数组的乘积 Product-of-Array-Except-Self

server/2024/9/25 16:09:06/

欢迎收藏Star我的Machine Learning Blog:https://github.com/purepisces/Wenqing-Machine_Learning_Blog。如果收藏star, 有问题可以随时与我交流, 谢谢大家!

链接:

  • 238_除自身以外数组的乘积

直觉

这个问题有点棘手,我看了 Neetcode 的解释。Neetcode 非常聪明。

给定输入: nums = [1,2,3,4]

预期输出是: [24,12,8,6]

首先,我们需要构建一个结果数组来存储每个乘积值。这个数组的长度与 nums 相同。例如:

  • 对于 1,乘积是 2 × 3 × 4
  • 对于 2,乘积是 1 × 3 × 4
  • 对于 3,乘积是 1 × 2 × 4
  • 对于 4,乘积是 1 × 2 × 3

我们可以注意到,数组是根据我们要知道其乘积的值分成两部分的。所以,我们可以计算前缀乘积和后缀乘积,然后将它们相乘。

对于前缀乘积,我们可以将其初始化为 1,并在遍历整个数组时更新其值。我们将计算每个位置的前缀乘积值。怎么做呢?res[i] = prefix,然后 prefix *= nums[i]。这意味着每次我们到达 nums[i] 时,前缀已经是我们可以直接使用并更新的前缀乘积值。

对于后缀乘积,我们也可以将其初始化为 1,并应以相反的顺序计算。此时,res 已经填充了前缀乘积值。然后,对于后缀乘积,我们将更新 res[i] *= postfix,然后更新 postfix *= nums[i]

方法

构建一个结果数组,其初始值为 [1] * len(nums),用于存储每个数字的乘积值。乘积分为前缀和后缀。在这种情况下,前缀将初始化为 1,我们将遍历整个数组以更新结果数组和前缀值。同样,后缀将初始化为 1,我们将以相反的顺序遍历整个数组以更新结果数组和后缀值。

复杂度

  • 时间复杂度:
    O ( n ) O(n) O(n)

    • 时间复杂度是 O ( n ) O(n) O(n),因为我们遍历数组两次:一次计算前缀乘积,一次计算后缀乘积。每次遍历的时间复杂度都是线性的。
  • 空间复杂度:
    O ( n ) O(n) O(n)

    • 空间复杂度是 O ( n ) O(n) O(n),因为我们使用了一个与输入数组 nums 长度相同的额外数组 res 来存储结果。前缀和后缀变量使用的空间是常数,但额外的结果数组使空间复杂度为线性。

代码

class Solution(object):def productExceptSelf(self, nums):""":type nums: List[int]:rtype: List[int]"""res = [1] * len(nums)prefix = 1for i in range(len(nums)):res[i] = prefixprefix *= nums[i]postfix = 1for i in range(len(nums)-1,-1,-1):res[i]*=postfix  postfix*=nums[i]return res

http://www.ppmy.cn/server/49335.html

相关文章

实验:贪心算法

实验二:贪心算法 【实验目的】 应用贪心算法求解活动安排问题。 【实验性质】 验证性实验。 【实验要求】 活动安排问题是可以用贪心算法有效求解的很好的例子。 问题:有n个活动的集合A{1,2,…,n},其中每个活动都要求使用同一资源&…

IDEA2023中使用run Dashboard面板?实现批量运行微服务

1、直接点击Add service--->Run Configuration Type---->Spring Boot 2、这样就出现了run Dashboard面板,可同时运行多个工程模块,shift选中所有启动类组命名(Group Configurations) 3、启动所有的项目

基数排序详解

目录 一、桶排序思想 1.1 什么是桶排序 1.2 桶排序的步骤 二、基数排序思想 2.1 什么是基数排序 2.2 实现方式 2.3 图解 三、代码思路 3.1 前置工作 3.2 映射 3.3 排序 四、C语言源码 一、桶排序思想 1.1 什么是桶排序 桶排序(Bucket sort)是一种排序算法&#xff…

WPS for Linux 无法使用fcitx中文输入法

现象 只能输入英文,按下Shift尝试切换输入法没有反应 解决办法 编辑如下文件/usr/bin/wps/usr/bin/et/usr/bin/wpp 分别对应wps word、excel、powerpoint,修改每个文件,加入如下代码并保存 export XMODIFIERS"imfcitx" export …

【云原生| K8S系列】Kubernetes Daemonset,全面指南

Kubernetes中的DaemonSet是什么? Kubernetes是一个分布式系统,Kubernetes平台管理员应该有一些功能可以在所有节点上运行特定于平台的应用程序。例如,在所有Kubernetes节点上运行日志代理。 这就是Daemonset发挥作用的地方。 Daemonset是一个原生的K…

Java | Leetcode Java题解之第149题直线上最多的点数

题目&#xff1a; 题解&#xff1a; class Solution {public int maxPoints(int[][] points) {int n points.length;if (n < 2) {return n;}int ret 0;for (int i 0; i < n; i) {if (ret > n - i || ret > n / 2) {break;}Map<Integer, Integer> map ne…

Web的UI自动化基础知识

目录 1 Web自动化入门基础1.1 自动化知识以及工具1.2 主流web自动化测试工具1.3 入门案例 2 使用工具的API2.1 元素定位2.1.1 id选择器2.1.2 name2.1.3 class_name选择器2.1.4 tag_name选择器2.1.5 link_text选择器2.1.6 partial_link_text选择器2.1.7 xpath选择器2.1.8 CSS选择…

《天软股票特色因子定期报告》

最新《天软股票特色因子定期报告》&#xff08;2024-06&#xff09;&#xff0c;抢先发布 内容概要如下&#xff1a; 天软特色因子A08006&#xff08;近一月日度买卖压力2&#xff09;从行业角度分析&#xff0c;在电子设备、石油石化行业表现稳定&#xff0c;无论在有效性、区…