算法 --- 记一道面试dp算法题
生活随笔
收集整理的這篇文章主要介紹了
算法 --- 记一道面试dp算法题
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
題目: 給定一個(gè)數(shù)組(長(zhǎng)度大于1),如下
let a = [1,4,3,4,5] // 長(zhǎng)度不確定,數(shù)值為整數(shù)要求寫一個(gè)函數(shù),返回該數(shù)組中,除本身數(shù)字之外其他元素的成積.即返回如下:
// 過(guò)程[4*3*4*5, 1*3*4*5, 1*4*4*5, 1*4*3*5, 1*4*3*4] // 結(jié)果[240, 60, 80, 60, 48]題目要求不使用除法,且時(shí)間復(fù)雜度為o(N)
思路如下:
可以看到,等式右邊,可以按照數(shù)組的下標(biāo)分為兩部分
即可以看作:
實(shí)現(xiàn)如下:
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 }說(shuō)明: 題目源自面試, 思路來(lái)自實(shí)驗(yàn)室大佬
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來(lái)咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的算法 --- 记一道面试dp算法题的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 西南科技大学oj题逆置顺序表
- 下一篇: IAR软件安装