動態規劃 數字三角形2

2022-08-18 06:42:14 字數 1292 閱讀 4802

【題目描述】

數字三角形

要求走到最後mod 100最大

【輸入格式】

第1行n,表示n行 <=25

第2到n+1行為每個的權值

【輸出格式】

mod 100最大值

【分析】

設定狀態f[i][j][k]表示(i,j)各自內是否mod 100可以為k。

狀態轉移方程:

f[i][j][k]=f[i+1][j][k+a[i+1][j]mod 100]  || f[i+1][j+1][k+a[i+1][j+1]mod 100]

一開始把f[1][1][a[1][1]]設定為true

【**】

1

var2 f:array[0..25,0..25,0..99]of

boolean;

3 a:array[0..25,0..25] of

longint;

4n,i,j,k:longint;

5function

max(n,m:longint):longint;

6begin

7if n>m then exit(n) else

exit(m);

8end;9

begin

10fillchar(f,sizeof(f),false);

11readln(n);

12for i:=1

to n do

13for j:=1

to i do

read(a[i][j]);

14 f[1][1][a[1][1]mod

100]:=true;

15for i:=2

to n do

16for j:=1

to i do

17for k:=0

to99

do18

begin

19if f[i-1][j][k] then f[i][j][(k+a[i][j])mod

100]:=true;

20if f[i-1][j-1][k] then f[i][j][(k+a[i][j])mod

100]:=true;

21end;22

for i:=99

downto0do

23for j:=1

to n do

24if f[n][j][i] then

25begin

26writeln(i);

27halt;

28end;29

end.

動態規劃 數字三角形

如圖所示的數字三角形,從頂部出發,在每一結點可以選擇向左走或得向右走,一直走到底層,要求找出一條路徑,使路徑上的值最大。第一行是數塔層數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 三角形行數。下面是三...

動態規劃 數字三角形

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