【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;
}
相关推荐
Wx120不知道取啥名15 分钟前
C语言之长整型有符号数与短整型有符号数转换
c语言·开发语言·单片机·mcu·算法·1024程序员节
测试老哥43 分钟前
Python+Selenium+Pytest+POM自动化测试框架封装(完整版)
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
Iareges44 分钟前
美团2025校招 广告算法工程师 面经
算法·面试·求职招聘·笔试·秋招
堇舟2 小时前
斯皮尔曼相关(Spearman correlation)系数
人工智能·算法·机器学习
西几3 小时前
代码训练营 day48|LeetCode 300,LeetCode 674,LeetCode 718
c++·算法·leetcode
liuyang-neu3 小时前
力扣第420周赛 中等 3324. 出现在屏幕上的字符串序列
java·算法·leetcode
想做白天梦4 小时前
双向链表(数据结构与算法)
java·前端·算法
小卡皮巴拉4 小时前
【力扣刷题实战】相同的树
c语言·算法·leetcode·二叉树·递归
zyhomepage4 小时前
科技的成就(六十四)
开发语言·人工智能·科技·算法·内容运营
想做白天梦4 小时前
多级反馈队列
java·windows·算法