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

由于该题不能使用除法,所以参考题解写一个左右乘积列表的方法

创建两个新的数组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;
}
相关推荐
knight_9___6 分钟前
大模型project面试4
人工智能·python·深度学习·算法·面试·agent
l1t11 分钟前
DeepSeek总结的欢迎来到 ORDER BY 丛林
数据库·算法
谙弆悕博士11 分钟前
【附C源码】二叉搜索树的C语言实现
c语言·开发语言·数据结构·算法·二叉树·项目实战·数据结构与算法
宵时待雨24 分钟前
回溯算法专题2:二叉树中的深搜
开发语言·数据结构·c++·笔记·算法·深度优先
刀法如飞31 分钟前
JavaScript 数组去重的 20 种实现方式,学会用不同思路解决问题
前端·javascript·算法
洛水水39 分钟前
【力扣100题】46.单词拆分
算法·leetcode·职场和发展
MicroTech20251 小时前
量子安全赋能协同智能,微算法科技(NASDAQ :MLGO)研发PQS-BFL后量子区块链联邦学习框架
科技·算法·安全
平行侠1 小时前
A19 工业设备故障决策树智能诊断系统
算法·决策树·机器学习
铮铭2 小时前
【论文阅读】世界模型发展脉络整理---Understanding World or Predicting Future? A Comprehensive Survey of World Models
论文阅读·人工智能·算法·机器人
灵智实验室2 小时前
PX4状态估计技术EKF2详解(四):EKF2 Output Predictor——从延迟估计到实时输出
算法·无人机·px 4