LeetCode:除了自身以外数组的乘积

java 复制代码
class Solution {
    public int[] productExceptSelf(int[] nums) {
        int n = nums.length;
        int[] answer = new int[n];
        answer[0] = 1;

        //计算左侧乘积
        for(int i = 1; i < n; i ++){
            answer[i] = answer[i - 1] * nums[i - 1];
        }
        //计算右侧乘积
        int rightProduct = 1;
        for(int i = n-1; i >= 0; i--){
            answer[i] *= rightProduct;
            rightProduct *= nums[i];
        }
        return answer;
    }
}

题目要求空间复杂度为O(1),同时说明输出数组不视为额外空间,所以可以抓住这个点使用输出数组进行计算。

同时在看到**"除自己之外"** 和**"两头夹击"**这种字眼的题目的时候可以考虑使用前缀数组和后缀数组,形成肌肉记忆。

相关推荐
大大杰哥几秒前
leetcode hot100(4)矩阵
算法·leetcode·矩阵
小白|5 分钟前
cmake:昇腾CANN构建系统完全指南
java·c++·算法
nebula-AI5 分钟前
人工智能导论:模型与算法(未来发展与趋势)
人工智能·神经网络·算法·机器学习·量子计算·automl·类脑计算
炽烈小老头7 分钟前
【每天学习一点算法 2026/05/21】课程表
学习·算法
luoganttcc10 分钟前
大模型是否即将到达算法极限
算法
叶小鸡38 分钟前
小鸡玩算法-力扣HOT100-动态规划(上)
算法·leetcode·动态规划
LuminousCPP44 分钟前
数据结构 - 线性表第三篇:基于顺序表实现 C 语言通讯录(基础功能篇)
c语言·数据结构·经验分享·笔记·算法
_日拱一卒1 小时前
LeetCode:114二叉树展开为链表
java·开发语言·算法
无小道1 小时前
Redis——哈希类型相关指令
redis·算法·哈希算法
凌波粒1 小时前
LeetCode--513.找树左下角的值(二叉树)
java·算法·leetcode