Leetcode 238.除了自身以外数组的乘积 JavaScript (Day 7)

js一刷

javascript 复制代码
var productExceptSelf = function(nums) {
    let answer=[];
    let prev=[];
    let after=[];
    prev[0]=1,after[nums.length-1]=1;
    for(let i=1;i<nums.length;i++){
        prev[i]=prev[i-1]*nums[i-1];
    }
    for(let i=nums.length-2;i>=0;i--){
        after[i]=after[i+1]*nums[i+1];
    }
    for(let i=0;i<nums.length;i++){
        answer[i]=prev[i]*after[i];
    }
    return answer;    
};

js一刷 优化

javascript 复制代码
var productExceptSelf = function(nums) {
    let answer=[];
    answer[0]=1;
    for(let i=1;i<nums.length;i++){
        answer[i]=answer[i-1]*nums[i-1];
    }
    let after=1;
    for(let i=nums.length-1;i>=0;i--){
        answer[i]*=after;
        after*=nums[i];
    }
    
    return answer;    
};

算法核心:由于不能用除法,采用前缀积乘以后缀积的方式
一个数的 前缀积=前一个数的前缀积 × 前一个数的值
后缀同理
分别用两个数组存储每一个位置的前缀积和后缀积

空间优化:只用一个数组,先用这个数组记录每个位置的前缀积,然后一边计算后缀积,一边把前缀积与后缀积相乘,乘完后更新后缀积

相关推荐
pe7er1 小时前
window管理开发环境篇 - 持续更新
前端·后端
We་ct2 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
陈随易6 小时前
有生之年系列,Nodejs进程管理pm2 v7.0发布
前端·后端·程序员
冰暮流星7 小时前
javascript之事件代理/事件委托
前端
陈随易8 小时前
AI时代,你还在坚持手搓文章吗
前端·后端·程序员
leoufung8 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了8 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
里欧跑得慢10 小时前
17. Flutter Hero动画实现:让界面过渡更加优雅
前端·css·flutter·web
IT_陈寒10 小时前
Vue的这个响应式陷阱,我debug了一整天才爬出来
前端·人工智能·后端
cn_mengbei11 小时前
用React Native开发OpenHarmony应用:Reanimated共享元素过渡
javascript·react native·react.js