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));
    }
}
相关推荐
Beaman102413 小时前
pytest框架
python·pytest
咋吃都不胖lyh13 小时前
python -m venv(Python 内置虚拟环境工具)和 conda create(Anaconda/Miniconda 环境管理工具)
python·环境
鸽鸽程序猿13 小时前
【项目】【抽奖系统】查询中奖记录
java·spring
计算机徐师兄13 小时前
Java基于微信小程序的物流管理系统【附源码、文档说明】
java·微信小程序·物流管理系统·java物流管理系统小程序·物流管理系统小程序·物流管理系统微信小程序·java物流管理系统微信小程序
ULTRA??13 小时前
STL deque 的详细特征
c++·算法
像风一样自由202013 小时前
基于PyTorch实现U-Net的路面裂缝检测系统
人工智能·pytorch·python
九死九歌13 小时前
【Sympydantic】使用sympydantic,利用pydantic告别numpy与pytorch编程中,tensor形状带来的烦人痛点!
开发语言·pytorch·python·机器学习·numpy·pydantic
Dxy123931021613 小时前
Python如何把二进制文本转PIL图片对象
python
yongui4783413 小时前
MATLAB 二维方腔自然对流 SIMPLE 算法
人工智能·算法·matlab
540_54013 小时前
ADVANCE Day22_复习日
人工智能·python·机器学习