[hdu4301]DP
题意:给一个2*n的矩形块,求把它分成k个连通块的方法数。(有公共边即视为联通)
思路:由于宽度只有2,于是很容易设计状态使问题满足阶段性以及无后效性。具体来说,令dp[i][j][0]和dp[i][j][1]表示把前i行分成j个连通块最后两个格子分别属于和不属于同一个连通块的方法数,于是有下面的状态转移方程:
dp[i][j][0]=dp[i-1][j-1][0..1]+dp[i-1][j][0]+dp[i-1][j][1]*2
dp[i][j][1]=dp[i-1][j-2][0..1]+dp[i-1][j][1]+dp[i-1][j-1][0..1]*2
- #pragma comment(linker, "/STACK:10240000,10240000")
- #include <iostream>
- #include <cstdio>
- #include <algorithm>
- #include <cstdlib>
- #include <cstring>
- #include <map>
- #include <queue>
- #include <deque>
- #include <cmath>
- #include <vector>
- #include <ctime>
- #include <cctype>
- #include <set>
- #include <bitset>
- #include <functional>
- #include <numeric>
- #include <stdexcept>
- #include <utility>
- using namespace std;
- #define mem0(a) memset(a, 0, sizeof(a))
- #define mem_1(a) memset(a, -1, sizeof(a))
- #define lson l, m, rt << 1
- #define rson m + 1, r, rt << 1 | 1
- #define rep_up0(a, b) for (int a = 0; a < (b); a++)
- #define rep_up1(a, b) for (int a = 1; a <= (b); a++)
- #define rep_down0(a, b) for (int a = b - 1; a >= 0; a--)
- #define rep_down1(a, b) for (int a = b; a > 0; a--)
- #define all(a) (a).begin(), (a).end()
- #define lowbit(x) ((x) & (-(x)))
- #define constructInt4(name, a, b, c, d) name(int a = 0, int b = 0, int c = 0, int d = 0): a(a), b(b), c(c), d(d) {}
- #define constructInt3(name, a, b, c) name(int a = 0, int b = 0, int c = 0): a(a), b(b), c(c) {}
- #define constructInt2(name, a, b) name(int a = 0, int b = 0): a(a), b(b) {}
- #define pchr(a) putchar(a)
- #define pstr(a) printf("%s", a)
- #define sstr(a) scanf("%s", a)
- #define sint(a) scanf("%d", &a)
- #define sint2(a, b) scanf("%d%d", &a, &b)
- #define sint3(a, b, c) scanf("%d%d%d", &a, &b, &c)
- #define pint(a) printf("%d\n", a)
- #define test_print1(a) cout << "var1 = " << a << endl
- #define test_print2(a, b) cout << "var1 = " << a << ", var2 = " << b << endl
- #define test_print3(a, b, c) cout << "var1 = " << a << ", var2 = " << b << ", var3 = " << c << endl
- #define mp(a, b) make_pair(a, b)
- #define pb(a) push_back(a)
- typedef unsigned int uint;
- typedef long long LL;
- typedef pair<int, int> pii;
- typedef vector<int> vi;
- const int dx[] = {, , -, , , , -, -};
- const int dy[] = {-, , , , , -, , - };
- const int maxn = 1e3 + ;
- const int md = ;
- const int inf = 1e9 + ;
- const LL inf_L = 1e18 + ;
- const double pi = acos(-1.0);
- const double eps = 1e-;
- template<class T>T gcd(T a, T b){return b==?a:gcd(b,a%b);}
- template<class T>bool max_update(T &a,const T &b){if(b>a){a = b; return true;}return false;}
- template<class T>bool min_update(T &a,const T &b){if(b<a){a = b; return true;}return false;}
- template<class T>T condition(bool f, T a, T b){return f?a:b;}
- template<class T>void copy_arr(T a[], T b[], int n){rep_up0(i,n)a[i]=b[i];}
- int make_id(int x, int y, int n) { return x * n + y; }
- int dp[][][];
- void init() {
- dp[][][] = ;
- dp[][][] = ;
- for (int i = ; i <= ; i ++) {
- rep_up1(j, * i) {
- dp[i][j][] = dp[i - ][j][] + dp[i - ][j][] * + dp[i - ][j - ][] + dp[i - ][j - ][];
- dp[i][j][] = dp[i - ][j][] + dp[i - ][j - ][] * + dp[i - ][j - ][] * ;
- if (j > ) dp[i][j][] += dp[i - ][j - ][] + dp[i - ][j - ][];
- dp[i][j][] %= md;
- dp[i][j][] %= md;
- }
- }
- }
- int main() {
- //freopen("in.txt", "r", stdin);
- init();
- int T;
- cin >> T;
- rep_up0(cas, T) {
- int n, k;
- cin >> n >> k;
- cout << (dp[n][k][] + dp[n][k][]) % md << endl;
- }
- return ;
- }
[hdu4301]DP的更多相关文章
- BZOJ 1911: [Apio2010]特别行动队 [斜率优化DP]
1911: [Apio2010]特别行动队 Time Limit: 4 Sec Memory Limit: 64 MBSubmit: 4142 Solved: 1964[Submit][Statu ...
- 2013 Asia Changsha Regional Contest---Josephina and RPG(DP)
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=4800 Problem Description A role-playing game (RPG and ...
- AEAI DP V3.7.0 发布,开源综合应用开发平台
1 升级说明 AEAI DP 3.7版本是AEAI DP一个里程碑版本,基于JDK1.7开发,在本版本中新增支持Rest服务开发机制(默认支持WebService服务开发机制),且支持WS服务.RS ...
- AEAI DP V3.6.0 升级说明,开源综合应用开发平台
AEAI DP综合应用开发平台是一款扩展开发工具,专门用于开发MIS类的Java Web应用,本次发版的AEAI DP_v3.6.0版本为AEAI DP _v3.5.0版本的升级版本,该产品现已开源并 ...
- BZOJ 1597: [Usaco2008 Mar]土地购买 [斜率优化DP]
1597: [Usaco2008 Mar]土地购买 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 4026 Solved: 1473[Submit] ...
- [斜率优化DP]【学习笔记】【更新中】
参考资料: 1.元旦集训的课件已经很好了 http://files.cnblogs.com/files/candy99/dp.pdf 2.http://www.cnblogs.com/MashiroS ...
- BZOJ 1010: [HNOI2008]玩具装箱toy [DP 斜率优化]
1010: [HNOI2008]玩具装箱toy Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 9812 Solved: 3978[Submit][St ...
- px、dp和sp,这些单位有什么区别?
DP 这个是最常用但也最难理解的尺寸单位.它与“像素密度”密切相关,所以 首先我们解释一下什么是像素密度.假设有一部手机,屏幕的物理尺寸为1.5英寸x2英寸,屏幕分辨率为240x320,则我们可以计算 ...
- android px转换为dip/dp
/** * 根据手机的分辨率从 dp 的单位 转成为 px(像素) */ public int dipTopx(Context context, float dpValue) { final floa ...
随机推荐
- Python - 关于带参数的装饰器的理解
[原创]转载请注明作者Johnthegreat和本文链接 关于装饰器的理解,特别像<盗梦空间>中的进入梦境和从梦境出来的过程,一层一层的深入梦境,然后又一层一层的返回,被带入梦境的是被装饰 ...
- <cstring>中常用的两个函数memset()和memcpy()
<cstring>是c++对c中的<string.h>进行了重写,这两个头文件中的函数用法是一样的,所以在用的时候包含哪个头文件都行.下面介绍一下 <cstring> ...
- php静态变量的销毁
什么都不说,先上代码: public function _childrenids($data,$cate_id,$clear=false) { static $arr = array(); if ($ ...
- $_FILES上传错误类型
$_FILES['file']['error']其值为 0,没有错误发生,文件上传成功. 其值为 1,上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值. 其值 ...
- Cannot find libcrypto in Ubuntu
https://stackoverflow.com/questions/13811889/cannot-find-libcrypto-in-ubuntu sudo apt-get install li ...
- java中Runnable和Callable的区别
文章目录 运行机制 返回值的不同 Exception处理 java中Runnable和Callable的区别 在java的多线程开发中Runnable一直以来都是多线程的核心,而Callable是ja ...
- C6 C7的开机启动流程
C6开机启动流程 1.内核引导,加电自检(通电后检查内核):检查bios的配置,检测硬件 装好系统之后才会进行以下内容 MBR 引导 (3.2.1...) GRUB菜单 (选择不同的系统)(按e,进入 ...
- HTML JavaScript 基础(上)
一.初识JavaScript JavaScript 和 Java什么关系? 半毛线关系都没有,只是名字有点重合而已. JavaScript 和python.C#.Java.Ruby一样,都是一门独立的 ...
- php beast windows编译教程
git clone https://github.com/Microsoft/php-sdk-binary-tools.git c:\php-sdk cd c:\php-sdk git checkou ...
- SQL 文件导入数据库
1.首先通过 xshell 连接数据库服务器,执行命令 mysql -u root -p 命令,按照提示输入密码,连接上数据库 2.在连接终端上执行命令 create database JD_Mode ...