第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問題,去搜搜看,總會有你想問的

自下而上和自上而下有什么區(qū)別?

自下而上和自上而下有什么區(qū)別?

自底向上方法(用于動態(tài)編程)包括首先查看“較小”的子問題,然后使用較小問題的解決方案解決較大的子問題。在自上而下的在于解決“自然地”的問題,并檢查是否已計(jì)算出前解決的子問題。我有點(diǎn)困惑。兩者有什么區(qū)別?
查看完整描述

3 回答

?
慕村9548890

TA貢獻(xiàn)1884條經(jīng)驗(yàn) 獲得超4個(gè)贊

自上而下和自下而上的DP是解決相同問題的兩種不同方法??紤]一種用于計(jì)算斐波那契數(shù)的記憶(自上而下)與動態(tài)(自底向上)編程解決方案。


fib_cache = {}


def memo_fib(n):

  global fib_cache

  if n == 0 or n == 1:

     return 1

  if n in fib_cache:

     return fib_cache[n]

  ret = memo_fib(n - 1) + memo_fib(n - 2)

  fib_cache[n] = ret

  return ret


def dp_fib(n):

   partial_answers = [1, 1]

   while len(partial_answers) <= n:

     partial_answers.append(partial_answers[-1] + partial_answers[-2])

   return partial_answers[n]


print memo_fib(5), dp_fib(5)

我個(gè)人覺得記憶很自然。您可以采用遞歸函數(shù)并通過機(jī)械過程將其記憶化(首先在緩存中查找答案,并在可能的情況下返回它,否則以遞歸方式對其進(jìn)行計(jì)算,然后在返回之前將計(jì)算結(jié)果保存在緩存中以備將來使用),而自下而上動態(tài)編程要求您對計(jì)算解決方案的順序進(jìn)行編碼,這樣在它依賴的較小問題之前就不會計(jì)算“大問題”。


查看完整回答
反對 回復(fù) 2019-10-04
  • 3 回答
  • 0 關(guān)注
  • 4234 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號