亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

自下而上和自上而下有什么區別?

自下而上和自上而下有什么區別?

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

3 回答

?
慕村9548890

TA貢獻1884條經驗 獲得超4個贊

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


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)

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


查看完整回答
反對 回復 2019-10-04
  • 3 回答
  • 0 關注
  • 4238 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號