動態規劃 DAG模型 硬幣問題

2021-07-11 23:36:16 字數 540 閱讀 1492

題目:有n種硬幣,面值分別為v1,v2,...vn,每種都有無限多。給定非負整數s,可以選用多少個硬幣,使得面值之和恰好為s?輸出硬幣數目的最小值和最大值!

dag問題的動態規劃求解:

#includeusing namespace std;

typedef long long ll;

typedef long double ld;

const double pi = acos(-1.0);

/ const int maxn=10010;

const int inf=1000000;

int n,s,v[maxn],minn[maxn],maxn[maxn];

void print_ans(int *d,int s)

//sort(v+1,v+1+n);

for(int i=1;i<=s;i++)

maxn[0]=0;

minn[0]=0;

for(int i=1;i<=s;i++)

} }for(int i=1;i<=s;i++) cout<

DAG上的動態規劃 硬幣問題

題目 有n種硬幣,面值分別為v1,v2,vn,每種都有無限多。給定非負整數s,可以選用多少個硬幣,使得面值之和恰好為s?輸出硬幣數目的最小值和最大值!分析 我們把每種面值看作乙個點!表示 還需要湊足的面值 初始狀態為s,目標狀態為0。那麼若當前狀態在i,每使用乙個硬幣j,狀態便轉移到i vj。inc...

DAG上的動態規劃 硬幣問題

問題描述 有n種硬幣,面值分別為v1,v2,v3.vn,每種硬幣有無限多,給定非負整數s,可以選用多少個硬幣,使得面值之和恰好為s?輸出硬幣數目的最小值和最大值,並且輸出各自的選取方案 如果有多種方案,則輸出硬幣編號字典序較小的方案,輸出每種選取方案的面值 分析 本質上市乙個dag上的路徑問題,我們...

DAG上的動態規劃 硬幣問題

題意 有n種硬幣,面值分別為v1,v2,vn,每種都有無限多。給定非負整數s,可以選用多少個硬幣,使得面值之和恰好為s?輸出硬幣數目的最小值和最大值。分析 我們把每種面值看作乙個點!表示 還需要湊足的面值 初始狀態為s,目標狀態為0。那麼若當前狀態在i,每使用乙個硬幣j,狀態便轉移到i vj。inc...