dp + 状态压缩 - Codeforces 580D Kefa and Dishes

简介: Kefa and Dishes  Problem's Link   Mean:  菜单上有n道菜,需要点m道。每道菜的美味值为ai。 有k个规则,每个规则:在吃完第xi道菜后接着吃yi可以多获得vi的美味值。

Kefa and Dishes 

Problem's Link


 

Mean: 

菜单上有n道菜,需要点m道。每道菜的美味值为ai。

有k个规则,每个规则:在吃完第xi道菜后接着吃yi可以多获得vi的美味值。

问:最多可以获得多少美味值?

(1≤m≤n≤18,0≤k≤n∗(n−1))

analyse:

经典的状压DP。

由于最多18道菜,可用一个数s(s<=2^18)来唯一标识一种状态。

对于一个状态s,枚举两个位置i和j:i从已选择的菜中选定,j从未选择的菜中选定。

下一个状态ss的就是:吃完i后接着吃j的所有状态的最大值。

转移过程:ss=s|(1<<j)

状态转移方程:dp[ss][j]=max(dp[ss][j],dp[s][i]+sa[j]+ad[i][j])

答案就是所有选择数量达到m的状态的最大值。

Time complexity: O( (2^n) *( n^2) )

 

view code

 

目录
相关文章
|
7月前
[leetcode ~dp ]279. 完全平方数
[leetcode ~dp ]279. 完全平方数
|
人工智能
动态规划(DP)——线性DP
动态规划(DP)——线性DP
[LeeCode][动态规划][简单]上楼梯
[LeeCode][动态规划][简单]上楼梯
57 0
|
机器学习/深度学习 人工智能
51nod 1055 最长等差数列 (dp好题)
51nod 1055 最长等差数列 (dp好题)
55 0
codeforces118——D. Caesar‘s Legions(DP)
codeforces118——D. Caesar‘s Legions(DP)
86 0
codeforces118——D. Caesar‘s Legions(DP)
|
人工智能
洛谷P1115-最大子段和(DP-最大子段和)
洛谷P1115-最大子段和(DP-最大子段和)
洛谷P1115-最大子段和(DP-最大子段和)
|
人工智能 vr&ar Perl
codeforces1509 C. The Sports Festival (区间DP)
codeforces1509 C. The Sports Festival (区间DP)
111 0