Leetcode:238. 除自身以外数组的乘积【题解超详细】

news2024/11/25 0:59:06

纯C语言实现(小白也能看明白)

题目

给你一个整数数组 nums,返回 数组 answer ,其中 answer[i] 等于 nums 中除 nums[i] 之外其余各元素的乘积 。

题目数据 保证 数组 nums之中任意元素的全部前缀元素和后缀的乘积都在  32 位 整数范围内。

不要使用除法,且在 O(n) 时间复杂度内完成此题。

难度:中等

题目链接:238. 除自身以外数组的乘积

解题思路 

由于该题不能使用除法 所以参考题解写一个左右乘积列表的方法 创建两个新的数组a,b 一个用于记录从左到右的乘积(类似于动态规划的思想)a 另一个记录从右到左的乘积 b(注意b是从右到左进行累乘) 而a的最左端为1,b的最右端为1 如此在结尾的时候只需要a*b即可 举例, ans[0]=a[0]*b[0] a[0]=1 b[0]=除了nums[0]以外所有元素的乘积

代码展示 

/**
 * Note: The returned array must be malloced, assume caller calls free().
 */
int* productExceptSelf(int* nums, int numsSize, int* returnSize){
    //前缀积*后缀积 == 除自身以外数组的乘积
    int *answer = (int*)malloc(sizeof(int)*numsSize);
    answer[0] = 1;//第一个数字前面没有数字了,第一个数字的前缀是1
    int i = 0;
    //前缀积
    for(i = 1;i<numsSize;i++)
    {
        answer[i] = answer[i-1]*nums[i-1];
    }
    //后缀积
    int rp[numsSize];//用来记录后缀积
    rp[numsSize-1] = 1;//因为最后边的数的后缀只能是1
    for(i = numsSize -1-1;i>=0;i--)
    {
        rp[i] = rp[i+1] * nums[i+1]; 
    }
    for(i = 0;i<numsSize;i++)
    {
        answer[i] = answer[i] * rp[i];//前缀积*后缀积
    }
    *returnSize = numsSize;//返回数组的大小
    return answer;//返回数组answer
}

 【超详细解析】

首先这是一个函数功能实现,一定要注意函数的参数。(int * nums ,这是传的是数组的地址,numsSize,这是数组的大小,*numsSize ,是要返回使用后数组的大小)

接下来是 代码分析

因为 根据题目的意思 我们要返回数组answer ,可以使用malloc()动态分配内存空间

int *answer = (int*)malloc(sizeof(int)*numsSize);

这行代码的意思是:创建了一个指针变量 answer,并使用 malloc() 函数动态分配了一块内存空间,大小为 sizeof(int)*numsSize 字节。其中,sizeof(int) 是指 int 类型在当前系统中所占据的字节数,numsSize 是一个变量,表示需要分配的元素个数。通过将 malloc() 返回的内存地址强制类型转换为 int*,将其赋值给指针变量 answer。这样就可以在动态分配的内存空间中存储 numsSize 个整数。

题目的意思 计算除自身以外数组的乘积,我们根据解题思路,采用 结果 == 前缀积 * 后缀积

就比如 1 2 3 4 5,这里 我采取除3以外数组的乘积(1*2*4*5),因为题目要求不要使用除法,且在 O(n) 时间复杂度内完成此题。所以 (1*2*4*5)变为 1*2 ( 前缀积)  * 4*5(后缀积),

这样 (1*2)*(4*5)

前缀积

这里我们以数组 [1,2,3,4] , 这里我们需要注意的是 数组的第一个元素的前缀乘积和数组的最后一个元素的后缀乘积是1。我们用answer数组来接收

answer[0] = 1;

(虽然answer数组要返回结果,我们可以先使用得到前缀之积,再借助另一个数组得到后缀之积,然后两数组各个元素相乘得到结果。这样就可一个减少一定的内存消耗)

接下里求前缀积(因为我们知道数组第一个元素的前缀之积是1)故从第二个元素开始计算

    //前缀积
    for(i = 1;i<numsSize;i++)
    {
        answer[i] = answer[i-1]*nums[i-1];
    }

接下来要求的是nums[1] 即第二个元素的前缀积

 

因为nums[1]  前面只有一个元素就是 1 故nums[1] 的前缀积 是1

再看nums[2]

 这时你可能有这样的疑问 为什么要 nums[1]*answer[1] 而不是 nums[0] * nums[1] 呢

这里你需要知道 乘积 肯定时连乘的 ,可以这样理解 answer数组 里面存放 的每一个阶段的乘积(其实就是每个nums数组对应的前缀的乘积)

nums[3]

 后缀乘积

    //后缀积
    int rp[numsSize];//用来记录后缀积
    rp[numsSize-1] = 1;//因为最后边的数的后缀只能是1
    for(i = numsSize -1-1;i>=0;i--)
    {
        rp[i] = rp[i+1] * nums[i+1]; 
    }

这提前声明了一个rp数组用来记录后缀积,数组最后的一个元素的后置缀之积 是1

rp[1]

 rp[2]

rp[3]

前缀积*后缀积

    for(i = 0;i<numsSize;i++)
    {
        answer[i] = answer[i] * rp[i];//前缀积*后缀积
    }

最后 answer数组与rp数组对应元素做乘积(answer[i] = answer[i] * rp[i])

 这的answer数组的大小与 nums 的数组大小一致 返回 numsSize ,数组返回 answer

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/937504.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

8. 损失函数与反向传播

8.1 损失函数 ① Loss损失函数一方面计算实际输出和目标之间的差距。 ② Loss损失函数另一方面为我们更新输出提供一定的依据。 8.2 L1loss损失函数 ① L1loss数学公式如下图所示&#xff0c;例子如下下图所示。 import torch from torch.nn import L1Loss inputs torch.tens…

冷启问题目前常见解决方案

1、冷启动的基本方式 随机冷启 个性化冷启 2、冷启动解决问题 冷启动保量 冷启动保量&#xff0c;保证每个item曝光的次数一样&#xff0c;实时统计已曝光的次数和要曝光的次数 冷启动结束过滤&#xff0c;如果需曝光的量越大&#xff0c;且越接近冷启结束时间&#xff0…

3.2 数据的表现形式及其运算

3.2.1 常量和变量 在计算机高级语言中&#xff0c;数据有两种表现形式&#xff1a;常量和变量。 1.常量 在程序运行过程中&#xff0c;其值不能被改变的量称为常量。如例3.1程序中的5,9,32和例3.2程序中的1000,0.0036,0.0225,0.0198是常量。数值常量就是数学中的常数。 常用的…

三、前端监控之Sentry的介绍

Sentry介绍 Sentry是一个开源的实时事件日志记录和聚合平台。它专门用于监视错误和提取执行适当的事后操作所需的所有信息, 而无需使用标准用户反馈循环的任何麻烦。支持 web 前后端、移动应用以及游戏&#xff0c;支持 Python、OC、Java、Go、Node、Django、RoR 等主流编程语…

【Docker】网络

文章目录 Docker 网络基础Docker网络管理Docker网络架构CNMLibnetwork驱动 常见的网络类型 Docker 网络管理命令docker network createdocker network inspectdocker network connectdocker network disconnectdocker network prunedocker network rmdocker network ls docker …

跳跃游戏 II【贪心算法】

跳跃游戏 II class Solution {public int jump(int[] nums) {int cur 0;//当前最大覆盖路径int next 0;//下一步的最大覆盖路径int res 0;//存放结果&#xff0c;到达终点时最少的跳跃步数for (int i 0; i < nums.length; i) {//遍历数组&#xff0c;以给出数组以一个…

老韦上新

知道韦东山老师的人很多&#xff0c;当然肯定可能也是有人不知道的&#xff0c;比如我今天吃饭的时候&#xff0c;我跟 JP 同学说&#xff0c;你认识韦东山老师吗&#xff1f;JP 同学说&#xff0c;「我不认识&#xff0c;他是不是搞 ODM 的&#xff1f;你知道的&#xff0c;我…

【python】输出高亮信息的内容

背景 日志是定位问题和数据分析的关键手段之一&#xff0c;尤其是在调试阶段&#xff0c;高效的、具有辨识度的日志可以非常快速准确的进行问题定位。shell中的echo命令自带文本格式化输出的功能&#xff0c;我们先来回顾下基本的语法&#xff0c;然后套用到python中即可。 s…

【kubernetes】使用kubepshere部署中间件服务

KubeSphere部署中间件服务 入门使用KubeSphere部署单机版MySQL、Redis、RabbitMQ 记录一下搭建过程 (内容学习于尚硅谷云原生课程) 环境准备 VMware虚拟机k8s集群&#xff0c;一主两从&#xff0c;master也作为工作节点&#xff1b;KubeSphere k8skubesphere devops比较占用磁…

手写数字识别之优化算法:观察Loss下降的情况判断合理的学习率

目录 手写数字识别之优化算法:观察Loss下降的情况判断合理的学习率 前提条件 设置学习率 学习率的主流优化算法 手写数字识别之优化算法:观察Loss下降的情况判断合理的学习率 我们明确了分类任务的损失函数&#xff08;优化目标&#xff09;的相关概念和实现方法&#xff…

Torrent Scanner插件导致网站重复登录

Torrent Scanner插件导致网站重复登录 网站登录成功后随便点击任意按钮&#xff0c;又重复跳回登录页面&#xff0c;可能原因是cookie的问题&#xff0c;不过博主遇到的是Torrent Scanner插件导致重复登录&#xff0c;解决方法&#xff1a;直接卸载或停止Torrent Scanner插件。…

C++贪吃蛇(控制台版)

C自学精简实践教程 目录(必读) 目录 主要考察 需求 输入文件 运行效果 实现思路 枚举类型 enum class 启动代码 输入文件data.txt 的内容 参考答案 学生实现的效果 主要考察 模块划分 文本文件读取 UI与业务分离 控制台交互 数据抽象 需求 用户输入字母表示方…

【leetcode 力扣刷题】双指针///原地扩充线性表

双指针///原地扩充线性表 剑指 Offer 05. 替换空格定义一个新字符串扩充字符串&#xff0c;原地替换思考 剑指 Offer 05. 替换空格 题目链接&#xff1a;剑指 Offer 05. 替换空格 题目内容&#xff1a; 这是一道简单题&#xff0c;理解题意&#xff0c;就是将字符串s中的空格…

windows系统依赖环境一键安装

window系统程序依赖库&#xff0c;可以联系我获取15958139685 脚本代码如下&#xff0c;写到1. bat文件中&#xff0c;双击直接运行&#xff0c;等待安装完成即可 Scku.exe -AVC.exe /SILENT /COMPONENTS"icons,ext\reg\shellhere,assoc,assoc_sh" /dir%1\VC

性能优化为什么那么重要

性能优化在计算机系统和软件开发中具有重要意义&#xff0c;是衡量工程师技术水平的试金石&#xff0c;是升职加薪必备技能&#xff0c;并且在各个技术领域都发挥举足轻重的作用。 嵌入式领域 嵌入式设备通常具有有限的硬件资源&#xff08;如 CPU、内存、存储空间等&#xff0…

命令行环境

sleep 20 延迟20秒 这个是操作系统的信号机制 ctrl z ^z可以恢复 jobs 可以查看 终端运行工作列表&#xff0c;bg可以将暂停的作业重新运行 通过kill暂停作业 通过 -KILL 之后才可以将 -HUP 作业悬挂起来 终端复路多用 会话 ^a p 上一个会话 ^ a n 下一个会话 别名 左右不能…

idea中创建springboot项目显示Spring Initializr Error

很长时间不创建springboot项目了,今天发现创建完成idea显示: Spring Initializr Error error:status:500项目中没有pom.xml文件.检查了一下原因是在创建的时候类型没有创建正确(之前记得都是默认),默认如下 需要选择创建maven完整工程那种,最下面那种只会生成pom.xml不会…

javaee spring 自动注入,如果满足条件的类有多个如何区别

如图IDrinkDao有两个实现类 方法一 方法二 Resource(name“对象名”) Resource(name"oracleDrinkDao") private IDrinkDao drinkDao;

《Java极简设计模式》第05章:原型模式(Prototype)

作者&#xff1a;冰河 星球&#xff1a;http://m6z.cn/6aeFbs 博客&#xff1a;https://binghe.gitcode.host 文章汇总&#xff1a;https://binghe.gitcode.host/md/all/all.html 源码地址&#xff1a;https://github.com/binghe001/java-simple-design-patterns/tree/master/j…

Unittest自动化测试框架vs Pytest自动化测试框架

引言 前面一篇文章Python单元测试框架介绍已经介绍了python单元测试框架&#xff0c;大家平时经常使用的是unittest&#xff0c;因为它比较基础&#xff0c;并且可以进行二次开发&#xff0c;如果你的开发水平很高&#xff0c;集成开发自动化测试平台也是可以的。而这篇文章主要…