[Java][Leetcode middle] 238. 除自身以外数组的乘积

第一个想法是:

想求出所有元素乘积,然后除以i对应的元素本书;这个想法是完全错误的:

  1. nums[I] 可能有0
  2. 题目要求了不能用除法

第二个想法是:

其实写之前就知道会超时,但是我什么都做不到啊!

双重循环,O(n2)

第三个做法: 借助辅助数组,官方题解

借助辅助数组:使用L[i],R[i],分别记录i左边和右边元素的乘积

那么res[I],就是L[I]*R[i]

java 复制代码
public int[] productExceptSelf2(int[] nums) {
        int len = nums.length;
        int[] result = new int[len];

        int[] R = new int[len]; //  the right of i: multiply
        int[] L = new int[len]; // the left of i: multiply

        L[0] = 1;
        R[len - 1] = 1;
        for (int i = 1; i < len; i++) {
            L[i] = L[i - 1] * nums[i - 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;
    }
}

做法四:先用result[]代替上文的L[]

java 复制代码
    public int[] productExceptSelf3(int[] nums) {
        int len = nums.length;
        int[] result = new int[len];

        result[0] = 1;
        for (int i = 1; i < len; i++) {
            result[i] = result[i - 1] * nums[i - 1];
        }

        int R = 1;
        for(int i = len-1 ; i >= 0 ; i--) {
            result[i] = R * result[i];

            R *= nums[i];
        }

        return result;
    }
相关推荐
##学无止境##2 分钟前
Maven 从入门到精通:Java 项目构建与依赖管理全解析(上)
java·开发语言·maven
根本睡不醒#3 分钟前
kali安装maven
java·web安全·网络安全·maven
小学生的信奥之路19 分钟前
力扣1116题:用C++实现多线程交替输出零、偶数、奇数
c++·leetcode·多线程
Aspartame~41 分钟前
企业级WEB应用服务器TOMCAT
java·运维·服务器·tomcat
你我约定有三1 小时前
分布式微服务--万字详解 微服务的各种负载均衡全场景以注意点
java·开发语言·windows·分布式·微服务·架构·负载均衡
奈斯。zs1 小时前
java面向对象高级02——单例类(设计模式)
java·开发语言·设计模式
拾荒的小海螺1 小时前
Redis:缓存雪崩、穿透、击穿的技术解析和实战方案
java·redis·缓存
旋风菠萝1 小时前
JVM易混淆名称
java·jvm·数据库·spring boot·redis·面试
雨叶微枫2 小时前
高效编解码协议之protobuf协议详解
java
NFA晨曦3 小时前
力扣刷题日常(7-8)
算法·leetcode·c#