DAY-4 | 力扣 - 求自身以外数组的乘积:区间划分,左右累乘,巧求乘积

简介: 该文档是关于LeetCode上的一道题目“Product of Array Except Self”的题解。提供了两种解题方法,一是暴力破解,即计算所有数的乘积后再逐个除以当前元素;二是左右累乘法,通过两次遍历数组分别计算左侧和右侧元素的乘积,避免了除法操作。其中,左右累乘法更优,代码实现中展示了这种方法。

一、题干


LeetCode链接


https://leetcode.cn/problems/product-of-array-except-self/



二、题解


1.暴力破解法


暴力破解法:直接将所有数据先乘积起来,然后再遍历数组,除以当前位置的数据即可。该方法比较简单,在此不作说明。


2.左右累乘法


这里以介绍左右累乘法为主。这个方法比较巧妙,值得我们积累。


思路


1. 要求除了某位置上的数本身的其它数的乘积,可以将乘积分为该数左边所有数的乘积 × 右边所有数的乘积。


2. 也即将乘积分两次进行:第一次先将每个位置左边的数据乘积计算出来,放到要返回的数组中;第二次再将对应位置右边的数据乘积计算出来,与返回数组对应位置的左半边乘积相乘,即得到结果。



以其中一个元素为例,这是该思路的实现过程



代码

int* productExceptSelf(int* nums, int numsSize, int* returnSize){ 
    int *ret = (int *)malloc(numsSize * sizeof(int)); //开辟返回数组空间
    *returnSize = numsSize; //returnSize为返回数组长度
    
    //初始化左右侧乘积为1
    int left = 1;
    int right = 1; 
 
    //第一次循环求当前位置左边的数字乘积,乘积结果left直接填入返回数组中     
    for (int i = 0; i < numsSize; i++) { 
        ret[i] = left;
        left *= nums[i]; 
    }
    //第二次循环求当前位置左边的数字乘积,对于返回数组的元素从后往前进行
    for (int i = numsSize - 1; i >= 0; i--) { 
        ret[i] *= right; //最后一个成绩不需要乘以最后元素,乘以1即可 
        right *= nums[i];
    }
    
    return ret; 
}





三、总结




相关文章
|
10天前
|
C++ Python
二刷力扣--数组
二刷力扣--数组
|
11天前
|
索引
【LeetCode刷题】二分查找:山脉数组的峰顶索引、寻找峰值
【LeetCode刷题】二分查找:山脉数组的峰顶索引、寻找峰值
|
11天前
|
算法
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
【经典LeetCode算法题目专栏分类】【第10期】排序问题、股票问题与TOP K问题:翻转对、买卖股票最佳时机、数组中第K个最大/最小元素
|
15天前
|
存储 算法 数据可视化
【模拟面试问答】深入解析力扣163题:缺失的区间(线性扫描与双指针法详解)
【模拟面试问答】深入解析力扣163题:缺失的区间(线性扫描与双指针法详解)
|
11天前
【LeetCode刷题】前缀和解决问题:742.寻找数组的中心下标、238.除自身以外数组的乘积
【LeetCode刷题】前缀和解决问题:742.寻找数组的中心下标、238.除自身以外数组的乘积
|
11天前
【LeetCode刷题】二分查找:寻找旋转排序数组中的最小值、点名
【LeetCode刷题】二分查找:寻找旋转排序数组中的最小值、点名
|
11天前
|
算法
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
【经典LeetCode算法题目专栏分类】【第6期】二分查找系列:x的平方根、有效完全平方数、搜索二位矩阵、寻找旋转排序数组最小值
|
10天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-2
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
10天前
|
算法 C++
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题-1
【数据结构与算法】:关于时间复杂度与空间复杂度的计算(C/C++篇)——含Leetcode刷题
|
11天前
|
算法
【LeetCode刷题】滑动窗口解决问题:串联所有单词的子串(困难)、最小覆盖子串(困难)
【LeetCode刷题】滑动窗口解决问题:串联所有单词的子串(困难)、最小覆盖子串(困难)