238. 除自身以外数组的乘积

238. 除自身以外数组的乘积

已解答

中等

提示

给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。

题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在 32 位 整数范围内。

不要使用除法, 且在 O(n) 时间复杂度内完成此题。

示例 1:

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

示例 2:

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

提示:

  • 2 <= nums.length <= 105
  • -30 <= nums[i] <= 30
  • 输入 保证 数组 answer[i]32 位 整数范围内

进阶: 你可以在 O(1) 的额外空间复杂度内完成这个题目吗?( 出于对空间复杂度分析的目的,输出数组 不被视为额外空间。)

转码路漫漫,官方题解好巧妙

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
        int[] res = new int[nums.length];
        int cur = 1;
        for(int i=0; i<nums.length; ++i){
            res[i] = cur;
            cur *= nums[i];
        }
        cur = 1;
        for(int i=nums.length-1; i>=0; --i){
            res[i] *= cur;
            cur *= nums[i];
        }
        return res;
    }
}
相关推荐
兮山与3 小时前
算法25.0
算法
爱编程的鱼3 小时前
想学编程作为今后的工作技能,学哪种语言适用性更强?
开发语言·算法·c#·bug
代码雕刻家3 小时前
1.6.课设实验-数据结构-栈、队列-银行叫号系统2.0
c语言·数据结构
yq14682860903 小时前
C (统计二进制中“1“的个数)
c语言·开发语言·算法
被AI抢饭碗的人3 小时前
算法题(254):灾后重建
算法·leetcode·职场和发展
深度学习机器3 小时前
RAG的另一种思路,基于文档树结构的推理型检索
人工智能·算法·架构
Violet_YSWY4 小时前
任何数据结构的构造或初始化,都应指定大小,避免数据结构无限增长吃光内存【示例】
java·数据结构
深度学习机器4 小时前
Agent架构新方向?Claude Skills工作原理解析
人工智能·算法·架构
蓝色汪洋4 小时前
最近联系人-有点疑惑
算法