力扣---------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;
}
}
相关推荐
FPGA几秒前
探讨4B/5B编码、8B/10B编码区别以及FPGA实现
数据结构
秋难降几秒前
线段树的深度解析(最长递增子序列类解题步骤)
数据结构·python·算法
楚韵天工22 分钟前
基于GIS的无人机模拟飞行控制系统设计与实现
深度学习·算法·深度优先·无人机·广度优先·迭代加深·图搜索算法
你也向往长安城吗1 小时前
推荐一个三维导航库:three-pathfinding-3d
javascript·算法
百度智能云2 小时前
VectorDB+FastGPT一站式构建:智能知识库与企业级对话系统实战
算法
John.Lewis3 小时前
数据结构初阶(13)排序算法-选择排序(选择排序、堆排序)(动图演示)
c语言·数据结构·排序算法
AI小白的Python之路3 小时前
数据结构与算法-排序
数据结构·算法·排序算法
DashVector3 小时前
如何通过Java SDK检索Doc
后端·算法·架构
zzz9333 小时前
transformer实战——mask
算法
一只鱼^_3 小时前
牛客周赛 Round 105
数据结构·c++·算法·均值算法·逻辑回归·动态规划·启发式算法