力扣---------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 位 整数范围内

我的思路是先求出第i个元素左边所有的积 在求出右边所有的积 在将左右乘右边 就能得出除自身之外所有的积

用 [1,2,3,4]来举例子

left数组的值应该为[1,1,2,6]

right数组的值应该为[24,12,4,1]

所以最后结果为[24,12,8,6]

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
        int [] left=new int[nums.length];
        int [] right=new int[nums.length];
        int [] result=new int[nums.length];

        left[0]=1;
        for (int i = 1; i < nums.length; i++) {
            left[i]=left[i-1]*nums[i-1];
        }

        right[nums.length-1]=1;
        for (int i = nums.length-2; i >=0; i--) {
            right[i]=right[i+1]*nums[i+1];
        }

        for (int i = 0; i < nums.length; i++) {
            result[i]=left[i]*right[i];
        }

        return result;
}
}
相关推荐
2501_941623328 小时前
智慧农业监控平台中的多语言语法引擎与实时决策实践
leetcode
轻抚酸~9 小时前
KNN(K近邻算法)-python实现
python·算法·近邻算法
Yue丶越12 小时前
【C语言】字符函数和字符串函数
c语言·开发语言·算法
小白程序员成长日记12 小时前
2025.11.24 力扣每日一题
算法·leetcode·职场和发展
有一个好名字12 小时前
LeetCode跳跃游戏:思路与题解全解析
算法·leetcode·游戏
AndrewHZ13 小时前
【图像处理基石】如何在图像中提取出基本形状,比如圆形,椭圆,方形等等?
图像处理·python·算法·计算机视觉·cv·形状提取
蓝牙先生13 小时前
简易TCP C/S通信
c语言·tcp/ip·算法
2501_9418705613 小时前
Python在高并发微服务数据同步与分布式事务处理中的实践与优化
leetcode
xiaoye-duck15 小时前
计数排序:高效非比较排序解析
数据结构
2501_9411477115 小时前
高并发微服务架构Spring Cloud与Dubbo在互联网优化实践经验分享
leetcode