力扣-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;
    }
}
相关推荐
Madison-No722 分钟前
【C++】探秘vector的底层实现
java·c++·算法
Swift社区30 分钟前
LeetCode 401 - 二进制手表
算法·leetcode·ssh
派大星爱吃猫32 分钟前
顺序表算法题(LeetCode)
算法·leetcode·职场和发展
liu****41 分钟前
8.list的模拟实现
linux·数据结构·c++·算法·list
地平线开发者1 小时前
征程 6 | 征程 6 工具链如何支持 Matmul/Conv 双 int16 输入量化?
算法·自动驾驶
程序员大雄学编程2 小时前
「深度学习笔记4」深度学习优化算法完全指南:从梯度下降到Adam的实战详解
笔记·深度学习·算法·机器学习
小O的算法实验室3 小时前
2022年ASOC SCI2区TOP,基于竞争与合作策略的金字塔粒子群算法PPSO,深度解析+性能实测,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
武帝为此3 小时前
【B树与B+树详解】
数据结构·b树
南莺莺3 小时前
邻接矩阵的基本操作
数据结构·算法··邻接矩阵
观望过往4 小时前
【Java数据结构】队列详解与经典 OJ 题目实战
java·数据结构