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

解法1

假设使用除法

java 复制代码
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

使用额外数组

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

java 复制代码
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动态计算,可以只用一个变量。

java 复制代码
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;
    }
}
相关推荐
希望有朝一日能如愿以偿31 分钟前
力扣题解(飞机座位分配概率)
算法·leetcode·职场和发展
Espresso Macchiato39 分钟前
Leetcode 3306. Count of Substrings Containing Every Vowel and K Consonants II
leetcode·滑动窗口·leetcode medium·leetcode 3306·leetcode周赛417
丶Darling.43 分钟前
代码随想录 | Day26 | 二叉树:二叉搜索树中的插入操作&&删除二叉搜索树中的节点&&修剪二叉搜索树
开发语言·数据结构·c++·笔记·学习·算法
JustCouvrir1 小时前
代码随想录算法训练营Day15
算法
小小工匠1 小时前
加密与安全_HOTP一次性密码生成算法
算法·安全·htop·一次性密码
中文英文-我选中文1 小时前
排序算法的理解
算法·排序算法
我明天再来学Web渗透1 小时前
【hot100-java】【二叉树的层序遍历】
java·开发语言·数据库·sql·算法·排序算法
数据分析螺丝钉2 小时前
力扣第240题“搜索二维矩阵 II”
经验分享·python·算法·leetcode·面试
no_play_no_games2 小时前
「3.3」虫洞 Wormholes
数据结构·c++·算法·图论
￴ㅤ￴￴ㅤ9527超级帅2 小时前
LeetCode hot100---数组及矩阵专题(C++语言)
c++·leetcode·矩阵