簡單動態規劃 動態的數字三角形

2022-05-03 17:09:07 字數 582 閱讀 5466

動態的數字三角形

難度級別:b; 執行時間限制:1000ms; 執行空間限制:51200kb; **長度限制:2000000b

試題描述

乙個數字組成的三角形,有n行,第i行有i個數。從第乙個數開始,每次可以往左下或右下走一格,直到走到最後一行,把沿途經過的數全部加起來。如何走才能得到最大的和?

舉個例子:

為了簡單起見,輸入時將每行的數依次輸入,第乙個數之前並不輸入空格。

輸入第一行:n,表示這個三角形共有n行

第二至n+1行:依次為這個數字三角形各行的資料(按順序輸入),兩數之間有乙個空格分隔。 

輸出乙個數,表示最大的和

輸入示例41

3 24 10 1

4 3 2 20

輸出示例

24

1 #include2 #include3

using

namespace

std;

4#define maxn 1000

5int

n,i,j,a[maxn][maxn];

6int

main()

7

view code

動態規劃 數字三角形

如圖所示的數字三角形,從頂部出發,在每一結點可以選擇向左走或得向右走,一直走到底層,要求找出一條路徑,使路徑上的值最大。第一行是數塔層數n 1 n 100 第二行起,按數塔圖形,有乙個或多個的整數,表示該層節點的值,共有n行。輸出最大值。5 1311 8 12 7 26 6 14 15 8 12 7...

動態規劃 數字三角形

7 3 8 8 1 0 2 7 4 4 4 5 2 6 5 在上面的數字三角形中尋找一條從頂部到底邊的路徑,使得 路徑上所經過的數字之和最大。路徑上的每一步都只能往左下或 右下走。只需要求出這個最大和即可,不必給出具體路徑。三角形的行數大於1小於等於100,數字為 0 99 5 三角形行數。下面是三...

動態規劃 數字三角形

在用動態規劃解題時,我們往往將和子問題相關的各個變數的一組取值,稱之為乙個 狀態 乙個 狀態 對應於乙個或多個子問題,所謂某個 狀態 下的 值 就是這個 狀態 所對應的子問題的解。以 數字三角形 為例,初始狀態就是底邊數字,值就是底邊數字值。定義出什麼是 狀態 以及在該 狀態 下的 值 後,就要找出...