力扣-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]

思路

题目要求不要用乘法,且复杂度为On。所以我们考虑用前缀乘积的方式来做,考虑到不止有前缀还有后缀我们需要一个等大的数组记录下前缀方便后面倒序累乘后缀乘积

解题方法

建立数组temp,temp[i]表示下标为i数的前缀乘积(不包括他本身因为题目要的就是除他本身的乘积),注意第一个temp[0]=1方便后续后缀乘积的计算。记录好前缀乘积后倒序累乘,用一个suf保存倒序累乘的值,suf初始值为1,遍历从n-2开始,n-1因为已经是最后一个不用算了

代码

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
        int n=nums.length;
        int[] temp=new int[n];
        int suf=1;
        for(int i=0;i<n;i++){
            if(i==0){
            temp[i]=1;
            continue; 
            }
            
            temp[i]=nums[i-1]*temp[i-1];
        }
        for(int i=n-2;i>=0;i--){
            suf=suf*nums[i+1];
            temp[i]=suf*temp[i];
        }
        return temp;
    }
}
相关推荐
BenChuat1 分钟前
Java常见排序算法实现
java·算法·排序算法
元亓亓亓23 分钟前
LeetCode热题100--105. 从前序与中序遍历序列构造二叉树--中等
算法·leetcode·职场和发展
纪元A梦42 分钟前
贪心算法在SDN流表优化中的应用
算法·贪心算法
JCBP_1 小时前
QT(4)
开发语言·汇编·c++·qt·算法
码熔burning1 小时前
JVM 垃圾收集算法详解!
jvm·算法
小柴狗1 小时前
C语言关键字详解:static、const、volatile
算法
仙俊红3 小时前
LeetCode每日一题,20250914
算法·leetcode·职场和发展
风中的微尘10 小时前
39.网络流入门
开发语言·网络·c++·算法
西红柿维生素11 小时前
JVM相关总结
java·jvm·算法
ChillJavaGuy12 小时前
常见限流算法详解与对比
java·算法·限流算法