LeetCode238☞除自身以外数组的乘积

关联LeetCode题号238

本题特点
  • 一开始使用双循环,果不其然超时。
  • 想到除自身外的元素,区别算出在当前元素之前的元素乘积,在当前元素之后的乘积,再将两者相乘
  • 思路类似 前缀和,前缀和是包括当前元素的 ,此题要求不包含当前元素
  • 所以求前缀积不包含当前元素,要先赋值,再乘积,将乘积值挪给下一个元素
本题思路
  1. 求出当前元素之前的元素的积
  2. 求出在当前元素之后的元素的积
  3. 将当前元素之前的元素积和当前元素之后的积相乘,得到就是除元素
python 复制代码
class Solution:
    def productExceptSelf(self, nums: List[int]) -> List[int]:
        answer = [1] * len(nums)
        pre = 1
        suf = 1
        # 求出在当前元素之前的元素的积
        for i in range(len(nums)):
            answer[i] = pre
            pre *=  nums[i]
        for j in range(len(nums)-1, -1, -1):
            # 将当前元素之前的元素积和当前元素之后的积相乘,得到就是除元素
            answer[j] *= suf
            # 求出在当前元素之后的元素的积
            suf *= nums[j]
        return answer
java写法
java 复制代码
package leetcode;

import org.junit.jupiter.api.Test;

import java.util.Arrays;

/**
 * File Description: ProductOfArrayExceptSelf_238
 * Author: 
 * Date: 2025/4/28 10:40
 */
public class ProductOfArrayExceptSelf_238 {
    public int[] productExceptSelf(int[] nums){
        int[] answer = new int[nums.length];
        Arrays.fill(answer, 1);
        int pre = 1, suf = 1;
        for(int i = 0; i < nums.length; i++){
            answer[i] = pre;
            pre *= nums[i];
        }
        for(int j = nums.length-1; j >= 0; j--){
            answer[j] *= suf;
            suf *= nums[j];
        }
        return answer;
    }

    @Test
    public void TestProductExceptSelf(){
        int[] nums = {1,2,3,4};
        int[] answer = productExceptSelf(nums);
        System.out.println(Arrays.toString(answer));
    }
}
相关推荐
CrissChan26 分钟前
Pycharm 函数注释
java·前端·pycharm
AI蜗牛之家1 小时前
Qwen系列之Qwen3解读:最强开源模型的细节拆解
人工智能·python
C++ 老炮儿的技术栈1 小时前
UDP 与 TCP 的区别是什么?
开发语言·c++·windows·算法·visual studio
殇者知忧1 小时前
【论文笔记】若干矿井粉尘检测算法概述
深度学习·神经网络·算法·随机森林·机器学习·支持向量机·计算机视觉
启航挨踢1 小时前
java学习电子书推荐
java
wgslucky1 小时前
Dubbo报错:module java.base does not “opens java.lang“ to unnamed module
java·开发语言·dubbo
whyeekkk1 小时前
python打卡第48天
开发语言·python
DougLiang3 小时前
关于easyexcel动态下拉选问题处理
java·开发语言
mochensage3 小时前
C++信息学竞赛中常用函数的一般用法
java·c++·算法
chengooooooo3 小时前
leetcode Top100 238. 除自身以外数组的乘积|数组系列
算法·leetcode