力扣-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,tempi表示下标为i数的前缀乘积(不包括他本身因为题目要的就是除他本身的乘积),注意第一个temp0=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;
    }
}
相关推荐
mxwin10 分钟前
Unity Shader exp 函数的算法与渲染应用
算法·unity·游戏引擎·shader
“码”力全开18 分钟前
AI视频分析误报优化完整流程
算法·架构·边缘计算
深盾科技_Virbox20 分钟前
深盾科技·Virbox产品体系全景解读:软件安全如何从加密锁走向全生命周期
java·大数据·算法·安全·软件需求
可编程芯片开发1 小时前
基于VSG虚拟同步发电机控制的三相并网逆变器带多组可变负载Simulink建模与仿真
算法
AI服务老曹1 小时前
国产NPU视觉算法参数配置说明
算法·性能优化·边缘计算
彦为君1 小时前
Redis最新版本特性
java·数据库·redis·算法·bootstrap
触底反弹2 小时前
🔥 字符串算法面试三连击:反转、回文、回文变种,搞懂这三题稳了!
前端·javascript·算法
aaaameliaaa2 小时前
计算斐波那契数(递归、迭代)(1,1,2,3,5.....)
c语言·开发语言·笔记·算法·排序算法
Jerry2 小时前
LeetCode 977. 有序数组的平方
算法
金融小师妹2 小时前
人工智能推演框架:非农降温信号如何重构黄金定价模型
数据结构·人工智能·机器学习·transformer