题目
分析
如果不出顺子,那么怎么出最优是可以DP解决的: d p [ i ] [ j ] [ k ] [ l ] dp[i][j][k][l] dp[i][j][k][l]表示一副牌有 i i i个炸弹、 j j j个三张、 k k k个顺子、 l l l个单牌的最优出法。在这个状态定义下,原来的 4 i + 3 j + 2 k + l 4i+3j+2k+l 4i+3j+2k+l张牌变成了 i + j + k + l i+j+k+l i+j+k+l张牌,你只需要考虑怎么组合(下面用 i i i、 j j j、 l l l、 l l l分别代指“炸弹”“三张”“对子”“单牌”这四种牌):
- 一张一张出完;
- 出一张 i i i,状态转移;
- 将一张 i i i变成一张 j j j和一张 l l l,状态转移(“炸弹”拆成一个三张和一个单牌);
- ……(共 13 13 13种情况,详见代码)
这样就可以轻(jue)松(wang)地完成DP了。
然后Dfs搜索顺子的打法,打了顺子过后就直接用上面的 d p dp dp值,将剩下的牌打完即可,注意处理一下大小王的情况(这道题里面大小王不算对子)。
代码
突然爱上了打空格XD
#

最低0.47元/天 解锁文章
538

被折叠的 条评论
为什么被折叠?



