【leetcode hot 100 238】除自身以外数组的乘积

解法一:(左右乘积列表)利用索引左侧所有数字的乘积和右侧所有数字的乘积(即前缀与后缀)相乘得到答案。

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
        int len = nums.length;
        int[] L = new int[len]; // 存放i左边的乘积
        int[] R = new int[len]; // 存放i右边的乘积
        int[] result = new int[len]; 

        // 第1个元素左边没有数据,乘积为0
        L[0]=1;
        for(int i=1;i<len;i++){
            L[i]=L[i-1]*nums[i-1];
        }

        // 第len个元素右边没有数据,乘积为0
        R[len-1]=1;
        for(int i=len-2;i>=0;i--){
            R[i]=R[i+1]*nums[i+1];
        }

        // 计算
        for(int i=0;i<len;i++){
            result[i]=L[i]*R[i];
        }
        return result;
    }
}

注意:

  • 左乘积数组:第1个元素左边没有数据,乘积为0
  • 右乘积数组:第len个元素右边没有数据,乘积为0
相关推荐
银之夏雪9 分钟前
ESLint 深度解析:原理、规则与插件开发实践
java·前端·javascript
重生之成了二本看我逆天改命走向巅峰21 分钟前
从0搭建Tomcat第二天:深入理解Servlet容器与反射机制
java·开发语言·笔记·学习·servlet·tomcat·idea
GIS小天22 分钟前
AI预测体彩排3新模型百十个定位预测+胆码预测+杀和尾+杀和值2025年3月4日第9弹
人工智能·算法·机器学习·彩票
rkmhr_sef24 分钟前
Java进阶:Dubbo
java·开发语言·dubbo
不止会JS29 分钟前
cursor使用经验分享(java后端服务开发向)
java·开发语言·经验分享·cursor
码熔burning33 分钟前
(二 十 三)趣学设计模式 之 解释器模式!
java·设计模式·解释器模式
三水气象台33 分钟前
对ArrayList中存储的TreeNode的排序回顾
java·数据结构·算法·huffman tree
牛马baby1 小时前
Java高频面试之集合-03
java·开发语言·面试
用手手打人1 小时前
多线程&JUC(二)
java·开发语言
@心都2 小时前
机器学习数学基础:40.结构方程模型(SEM)中卡方值与卡方自由度比
人工智能·算法·机器学习