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));
    }
}
相关推荐
惊讶的猫5 小时前
LSTM论文解读
开发语言·python
cynicme5 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员5 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称6 小时前
【递归】二进制字符串中的第K位
c++·算法
测试老哥6 小时前
软件测试之单元测试知识总结
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例
buvsvdp50059ac6 小时前
如何在VSCode中设置Python解释器?
ide·vscode·python
mjhcsp6 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛6 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
A阳俊yi6 小时前
Spring Data JPA
java·开发语言
小王不爱笑1326 小时前
Spring AOP(AOP+JDBC 模板 + 转账案例)
java·后端·spring