238. 除自身以外数组的乘积 --力扣 --JAVA

题目

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

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

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

解题思路

  1. 最简单的是把所有元素相乘,出去当前的元素值;
  2. 可以理解成当前元素把数组分割成左右两部分,而乘积可以通过左侧数组值乘以右侧数组值来进行计算;
  3. 通过循环对左右侧数组的值进行赋值,即累乘,当前元素值可设置为1不影响结果。

代码展示

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
        int size = nums.length;
        int[] ans = new int[size];
        int[] left = new int[size];
        left[0] = 1;
        int[] right = new int[size];
        right[size - 1] = 1;
        for (int i = 1; i < size; i++){
            left[i] = nums[i - 1] * left[i - 1];
        }
        for (int i = size - 2; i >= 0 ; i--){
            right[i] = right[i + 1] * nums[i + 1];
        }
        for (int i = 0; i < size; i++){
            ans[i] = left[i] * right[i];
        }
        return ans;
    }
}
相关推荐
AndrewHZ1 分钟前
【图像处理基石】如何使用大模型进行图像处理工作?
图像处理·人工智能·深度学习·算法·llm·stablediffusion·可控性
AndrewHZ5 分钟前
【图像处理基石】图像处理的基础理论体系介绍
图像处理·人工智能·算法·计算机视觉·cv·理论体系
稚辉君.MCA_P8_Java2 小时前
Gemini永久会员 Java实现的暴力递归版本
java·数据结构·算法
冯诺依曼的锦鲤2 小时前
算法练习:差分
c++·学习·算法
有意义2 小时前
栈数据结构全解析:从实现原理到 LeetCode 实战
javascript·算法·编程语言
鹿鹿鹿鹿isNotDefined2 小时前
逐步手写,实现符合 Promise A+ 规范的 Promise
前端·javascript·算法
封奚泽优3 小时前
下降算法(Python实现)
开发语言·python·算法
im_AMBER3 小时前
算法笔记 16 二分搜索算法
c++·笔记·学习·算法
高洁013 小时前
【无标具身智能-多任务与元学习】
神经网络·算法·aigc·transformer·知识图谱
识醉沉香3 小时前
广度优先遍历
算法·宽度优先