算法 --- > 记一道面试dp算法题

题目: 给定一个数组(长度大于1),如下

let a = [1,4,3,4,5] 
// 长度不确定,数值为整数

要求写一个函数,返回该数组中,除本身数字之外其他元素的成积.即返回如下:

// 过程[4*3*4*5, 1*3*4*5, 1*4*4*5, 1*4*3*5, 1*4*3*4]
// 结果[240, 60, 80, 60, 48]

题目要求不使用除法,且时间复杂度为o(N)
思路如下:

/*
	假设返回的数组为 res
	res[0] = arr[1] * arr[2] * arr[3] * arr[4] 
	res[1] = arr[0] * arr[2] * arr[3] * arr[4]
	res[2] = arr[0] * arr[1] * arr[3] * arr[4]
	res[3] = arr[0] * arr[1] * arr[2] * arr[4]
	res[4] = arr[0] * arr[1] * arr[2] * arr[3]
*/ 

可以看到,等式右边,可以按照数组的下标分为两部分
在这里插入图片描述
即可以看作:

/*
	res[0] = a[0] * b[0]
	res[1] = a[1] * b[1]
	res[2] = a[2] * b[2]
	res[3] = a[3] * b[3]
	res[4] = a[4] * b[4]

	其中: 
	a[0] = 1
	a[1] = arr[0]
	a[2] = arr[1] * arr[0]
	a[3] = arr[2] * arr[1] * arr[0]
	a[4] = arr[3] * arr[2] * arr[1] * arr[0]
	
	进一步:
	a[0] = 1
	a[1] = arr[0] * a[0]  =>  arr[0]
	a[2] = arr[1] * a[1]  =>  arr[1] * arr[0]
	...
	a[n] = arr[n-1] * a[n-1]

    同理:
    b[n] = 1
    b[n - 1] = arr[n+1] * b[n + 1]  
	
*/

实现如下:

function getArr(arr){
	let len = arr.length
	, a = new Array(len).fill(1)
	, b = new Array(len).fill(1)
	, res = []
	for(let i = 1; i < len; i++){
		a[i] = arr[i - 1] * a[i -1]
	}
	for(let i = len - 2; i > -1; i--){
		b[i] = arr[i+1] * b[i+1]
	}
	for(let i = 0; i<=len - 1; i++){
		res[i] = a[i] * b[i]
	}
	return res
}

说明: 题目源自面试, 思路来自实验室大佬

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值