状压
泽7
这个作者很懒,什么都没留下…
展开
专栏收录文章
- 默认排序
- 最新发布
- 最早发布
- 最多阅读
- 最少阅读
-
状压dp 互不侵犯
这是一道典型的状压dp题。我们可以将每一行棋子的状态用二进制存储。 dp[i][j][k]表示到第i行第j种状态已有k个棋子。那么状态转移方程为dp[i+1][p][k+num[p]]+=dp[i][j][k] (p指下一行的状态)。我们可以用位运算来判断状态是否合法,上下棋子是否攻击到。上代码#include<iostream>#include<cstdio>...原创 2019-02-27 16:30:40 · 152 阅读 · 0 评论 -
状压dp——涂抹果酱
这道题的状态有三种红绿蓝。所以按一般的状压dp的做法,不难想到我们可以用三进制的形式来储存每一行的状态。但因为K行蛋糕已经涂好,所以应该先判断K行蛋糕是否符合要求。按常规思路处理时,不要忘记考虑当i=k这种情况就可以了。#include<iostream>#include<cstdio>using namespace std;const int mod=1e6...原创 2019-02-27 16:43:09 · 371 阅读 · 0 评论 -
炮兵阵地
题目描述司令部的将军们打算在NM的网格地图上部署他们的炮兵部队。一个NM的地图由N行M列组成,地图的每一格可能是山地(用“H” 表示),也可能是平原(用“P”表示),如下图。在每一格平原地形上最多可以布置一支炮兵部队(山地上不能够部署炮兵部队);一支炮兵部队在地图上的攻击范围如图中黑色区域所示:如果在地图中的灰色所标识的平原上部署一支炮兵部队,则图中的黑色的网格表示它能够攻击到的区域:沿横向...原创 2019-02-27 17:00:56 · 120 阅读 · 0 评论
分享