在講述dp演算法的時候,乙個經典的例子就是數塔問題,它是這樣描述的:
有如下所示的數塔,要求從頂層走到底層,若每一步只能走到相鄰的結點,則經過的結點的數字之和最大是多少?
dp問題一般都是從後向前,(後文有從前向後的動態規劃**分析)因為要找到最大值的連線,我們可以從倒數第二行開始,在2時可以選擇19和7,這個時候我們選19,並把它加在2上,這代表著若走到這,後面最多能再提供21這樣大小的值,如圖
下一步同理,在10,6,8各個節點對左右子節點進行選擇,挑選最大的
最後即可得出最大值是59,具體實現c**如下
#include int main()
} for(i=n;i>=2;i--)
}printf("%d\n",a[1][1]);
} return 0;
}
這裡只得到了最大值,那麼路徑怎麼得到呢,只要遍歷每一行最大值,把他們求出來,然後相減,就能得出路徑上各個數字大小了。
那麼從上往下能不能進行動態規劃呢?答案是可以的!先說一說思路,其實就是和從下往上相反,這裡應該把上面的數加到下面去,但是要注意塔的邊上的數只有乙個父節點,因此不用進行規劃,直接加下來就行,最後可以在第n行得到一排數字,分別代表到達各葉子節點的最大值,**即執行效果如下
可以看見a[5][j],也就是第五行,已經得到了各個點所能得到的最大值,以上就是數塔通用的由下往上,及由上往下的動態規劃方法。
DP數塔問題
有如下所示的數塔,要求從頂層走到底層,若每一步只能走到相鄰的結點,則經過的結點的數字之和最大是多少?有一組測試樣例,測試例項的第一行是乙個整數n 1 n 100 表示數塔的高度,接下來用n行數字表示數塔,其中第i行有個i個整數,且所有的整數均在區間 0,99 內。output 對於每個測試例項,輸出...
DP問題之數塔問題
問題描述 考慮下面的數字金字塔,寫乙個程式來計算從最高點開始,在底部任意處結束經過的數字和最大,每一步可以走到左下和右下的點。73 8 8 1 0 2 7 4 4 4 5 2 6 5 變形後 3 8 8 1 0 2 7 4 4 4 5 2 6 5 問題分析 可以先對金字塔進行變形,如上。對於數字金字...
HDU2084 數塔(經典dp)
problem description 在講述dp演算法的時候,乙個經典的例子就是數塔問題,它是這樣描述的 有如下所示的數塔,要求從頂層走到底層,若每一步只能走到相鄰的結點,則經過的結點的數字之和最大是多少?已經告訴你了,這是個dp的題目,你能ac嗎?input 輸入資料首先包括乙個整數c,表示測試...