力扣-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;
    }
}
相关推荐
Xの哲學1 小时前
TCP 连接管理:深入分析四次握手与三次挥手
网络·网络协议·算法
华清远见成都中心4 小时前
基于深度学习的异常检测算法在时间序列数据中的应用
人工智能·深度学习·算法
梁辰兴5 小时前
数据结构:串、数组与广义表
开发语言·数据结构·c··数组·广义表
এ᭄画画的北北5 小时前
力扣-347.前K个高频元素
算法·leetcode
月殇_木言8 小时前
算法基础 第3章 数据结构
数据结构·算法
亮亮爱刷题8 小时前
算法提升之树上问题-(LCA)
数据结构·算法·leetcode·深度优先
火车叨位去19499 小时前
力扣top100(day03-01)--二叉树 03
算法·leetcode·职场和发展
岁忧9 小时前
(LeetCode 每日一题) 1780. 判断一个数字是否可以表示成三的幂的和 (数学、三进制数)
java·c++·算法·leetcode·职场和发展·go
浩少7029 小时前
LeetCode-16day:栈
java·数据结构·算法
胖咕噜的稞达鸭11 小时前
数据结构---关于复杂度的基础解析与梳理
c语言·数据结构·算法·leetcode