238. 除自身以外数组的乘积

解法1

假设使用除法

class Solution {
    public int[] productExceptSelf(int[] nums) {
        int cnt0 = 0, idx0 = 0, lc = 1;
        for (int i = 0; i < nums.length; i++) {
            if (nums[i] == 0) {
                cnt0++;
                idx0 = i;
            } else {
                lc *= nums[i];
            }
        }
        int[] ans = new int[nums.length];
        if (cnt0 == 1) {
            ans[idx0] = lc;
        } else if (cnt0 < 1) {
            for (int i = 0; i < ans.length; i++) {
                ans[i] = lc / nums[i];
            }
        }
        return ans;
    }
}

解法2

使用额外数组

从左向右乘法,从右向左乘法

class Solution {
    public int[] productExceptSelf(int[] nums) {
        int n = nums.length;
        if (n < 2) {
            return nums;
        }
        int[] left = new int[n];
        int[] right = new int[n];
        int[] ans = new int[n];
        int base = 1;
        for (int i = 0; i < n; i++) {
            base *= nums[i];
            left[i] = base;
        }
        base = 1;
        for (int i = n - 1; i > -1; i--) {
            base *= nums[i];
            right[i] = base;
        }
        ans[0] = right[1];
        ans[n - 1] = left[n - 2];
        for (int i = 1; i < n - 1; i++) {
            ans[i] = left[i - 1] * right[i + 1];
        }
        return ans;
    }
}

解法3

常数项额外空间

left或者right可以作为最终数组,节约空间。

right动态计算,可以只用一个变量。

class Solution {
    public int[] productExceptSelf(int[] nums) {
        int n = nums.length;
        if (n < 2) {
            return nums;
        }
        int[] left = new int[n];
        left[0] = 1;
        for (int i = 1; i < n; i++) {
            left[i] = left[i - 1] * nums[i - 1];
        }
        int r = 1;
        for (int i = n - 2; i > -1; i--) {
            r *= nums[i + 1];
            left[i] *= r;
        }
        return left;
    }
}

相关推荐

  1. 【Leetcode】238.自身以外乘积

    2024-06-09 05:56:01       50 阅读
  2. 【力扣】238. 自身以外乘积

    2024-06-09 05:56:01       14 阅读
  3. 238. 自身以外乘积

    2024-06-09 05:56:01       12 阅读
  4. 238. 自身以外乘积/41. 缺失第一个正数

    2024-06-09 05:56:01       14 阅读
  5. 【力扣100】238.自身以外乘积

    2024-06-09 05:56:01       40 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-09 05:56:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-09 05:56:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-09 05:56:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-09 05:56:01       20 阅读

热门阅读

  1. linux 系统被异地登录,cpu占用拉满100%

    2024-06-09 05:56:01       11 阅读
  2. 2 程序的灵魂—算法-2.2 简单算法举例-【例 2.4】

    2024-06-09 05:56:01       14 阅读
  3. 如何在 C# 中轻松从 HTML 中提取纯文本

    2024-06-09 05:56:01       9 阅读
  4. scrapy入门例子:获取百度热搜

    2024-06-09 05:56:01       9 阅读
  5. mysql解决深度分页的问题

    2024-06-09 05:56:01       11 阅读
  6. 自动驾驶人工智能

    2024-06-09 05:56:01       9 阅读
  7. 平滑值(pinghua)

    2024-06-09 05:56:01       8 阅读
  8. Ubuntu bash按Table不联想

    2024-06-09 05:56:01       10 阅读