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

server/2024/10/9 8:18:26/

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

代码:

int* productExceptSelf(int* nums, int numsSize, int* returnSize)
{*returnSize = numsSize;int* pef = (int*)malloc(sizeof(int) * numsSize);int* suf = (int*)malloc(sizeof(int) * numsSize);pef[0] = 1;suf[numsSize - 1] = 1;for (int i = 1; i < numsSize; i++){pef[i] = pef[i - 1] * nums[i - 1];}for (int i = numsSize - 2; i >= 0; i--){suf[i] = suf[i + 1] * nums[i + 1];}
int* arr = (int*)malloc(sizeof(int) * numsSize);for (int i = 0; i < numsSize; i++){arr[i] = pef[i] * suf[i];}return arr;
}


 

 


http://www.ppmy.cn/server/129178.html

相关文章

Spring Boot实现新闻个性化推荐

1系统概述 1.1 研究背景 如今互联网高速发展&#xff0c;网络遍布全球&#xff0c;通过互联网发布的消息能快而方便的传播到世界每个角落&#xff0c;并且互联网上能传播的信息也很广&#xff0c;比如文字、图片、声音、视频等。从而&#xff0c;这种种好处使得互联网成了信息传…

测试用例的编写

1.基本概念&#xff1a; 编写测试用例是确保代码质量和正确性的重要环节&#xff0c;尤其是在软件开发和维护过程中。测试用例通常用于验证功能是否符合预期&#xff0c;并及时发现潜在的错误或漏洞。 2.常见的测试用例编写方法&#xff1a; 等价划分法&#xff0c;边界值法&a…

毕设 深度学习语义分割实现弹幕防遮(源码分享)

文章目录 0 简介1 课题背景2 技术原理和方法2.1基本原理2.2 技术选型和方法 3 实例分割4 实现效果最后 0 简介 今天学长向大家分享一个毕业设计项目 毕业设计 深度学习语义分割实现弹幕防遮(源码分享) &#x1f9ff; 项目分享:见文末! 1 课题背景 弹幕是显示在视频上的评论…

Authentication Lab | IP Based Auth Bypass

关注这个靶场的其它相关笔记&#xff1a;Authentication Lab —— 靶场笔记合集-CSDN博客 0x01&#xff1a;IP Based Auth Bypass 前情提要 有些开发人员为了图方便&#xff0c;会给站点设置一个 IP 白名单&#xff0c;如果访问站点的用户的 IP 在白名单内&#xff0c;则允许访…

上海AI Lab视频生成大模型书生.筑梦环境搭建推理测试

引子 最近视频生成大模型层出不穷&#xff0c;上海AI Lab推出新一代视频生成大模型 “书生・筑梦 2.0”(Vchitect 2.0)。根据官方介绍&#xff0c;书生・筑梦 2.0 是集文生视频、图生视频、插帧超分、训练系统一体化的视频生成大模型。OK&#xff0c;那就让我们开始吧。 一、模…

json修改key python

使用Python修改JSON键名 在现代应用中&#xff0c;JSON&#xff08;JavaScript Object Notation&#xff09;是一种轻量级的数据交换格式。由于其易于人类阅读和编写&#xff0c;同时也便于机器解析和生成&#xff0c;JSON广泛应用于API和数据存储。本文将探讨如何在Python中修…

LSTM模型实现电力数据预测

关于深度实战社区 我们是一个深度学习领域的独立工作室。团队成员有&#xff1a;中科大硕士、纽约大学硕士、浙江大学硕士、华东理工博士等&#xff0c;曾在腾讯、百度、德勤等担任算法工程师/产品经理。全网20多万粉丝&#xff0c;拥有2篇国家级人工智能发明专利。 社区特色&a…

使用Qt实现实时数据动态绘制的折线图示例

基于Qt的 QChartView 和定时器来动态绘制折线图。它通过动画的方式逐步将数据点添加到图表上&#xff0c;并动态更新坐标轴的范围&#xff0c;提供了一个可以实时更新数据的折线图应用。以下是对代码的详细介绍及其功能解析&#xff1a; 代码概述 该程序使用Qt的 QChartView…