首先是状态压缩DP。。。

然后我们发现转移都是一样的。。。可以矩阵优化。。。

于是做完啦QAQQQ

题目读不懂?恩多读几遍就读懂了,诶诶诶!别打我呀!

 /**************************************************************
Problem: 4000
User: rausen
Language: C++
Result: Accepted
Time:208 ms
Memory:920 kb
****************************************************************/ #include <cstdio>
#include <cstring>
#include <vector> using namespace std;
typedef unsigned int uint;
const int N = ; inline int read(); int n, m, p, K, Mx;
int a[N][N], f[N];
vector <int> mp[];
uint ans; struct mat {
uint x[][];
mat() {
memset(x, , sizeof(x));
}
inline void one() {
static int i;
*this = mat();
for (i = ; i < Mx; ++i) x[i][i] = ;
}
inline uint* operator [] (int t) {
return x[t];
} inline mat operator * (const mat &m) const {
static mat res;
static int i, j, k;
res = mat();
for (i = ; i < Mx; ++i)
for (j = ; j < Mx; ++j)
for (k = ; k < Mx; ++k)
res[i][j] += x[i][k] * m.x[k][j];
return res;
}
} A; inline mat pow(const mat& m, int y) {
static mat x, res;
x = m, res.one();
int i, j;
while (y) {
if (y & ) res = res * x;
x = x * x, y >>= ;
}
return res;
} inline bool in(int x) {
return <= x && x < m;
} inline bool check(int s1, int s2) {
static int i, j, t;
for (i = ; i < m; ++i) if ((s1 >> i) & ) {
for (j = ; j < mp[].size(); ++j)
if (in(t = i + mp[][j]) && ((s1 >> t) & )) return ;
for (j = ; j < mp[].size(); ++j)
if (in(t = i + mp[][j]) && ((s2 >> t) & )) return ;
}
for (i = ; i < m; ++i) if ((s2 >> i) & ) {
for (j = ; j < mp[].size(); ++j)
if (in(t = i + mp[][j]) && ((s2 >> t) & )) return ;
for (j = ; j < mp[].size(); ++j)
if (in(t = i + mp[][j]) && ((s1 >> t) & )) return ;
}
return ;
} int main() {
int i, j;
n = read(), m = read(), p = read(), K = read(), Mx = << m;
for (i = ; i < ; ++i)
for (j = ; j < p; ++j)
if (read() && !(i == && j == K)) mp[i].push_back(j - K);
for (i = ; i < Mx; ++i)
for (j = ; j < Mx; ++j) A[i][j] = check(i, j);
for (i = ; i < Mx; ++i) f[i] = bool(A[][i]);
A = pow(A, n);
for (i = ; i < Mx; ++i) ans += f[i] * A[i][];
printf("%u\n", ans);
return ;
} inline int read() {
static int x;
static char ch;
x = , ch = getchar();
while (ch < '' || '' < ch)
ch = getchar();
while ('' <= ch && ch <= '') {
x = x * + ch - '';
ch = getchar();
}
return x;
}

(p.s. 这道题是0开始标号的。。。注意了QAQQQ)

BZOJ4000 [TJOI2015]棋盘的更多相关文章

  1. BZOJ4000 TJOI2015棋盘(状压dp+矩阵快速幂)

    显然每一行棋子的某种放法是否合法只与上一行有关,状压起来即可.然后n稍微有点大,矩阵快速幂即可. #include<iostream> #include<cstdio> #in ...

  2. [BZOJ4000][TJOI2015]棋盘(状压DP+矩阵快速幂)

    题意极其有毒,注意给的行列都是从0开始的. 状压DP,f[i][S]表示第i行状态为S的方案数,枚举上一行的状态转移.$O(n2^{2m})$ 使用矩阵加速,先构造矩阵a[S1][S2]表示上一行为S ...

  3. BZOJ4000 [TJOI2015]棋盘 【状压dp + 矩阵优化】

    题目链接 BZOJ4000 题解 注意题目中的编号均从\(0\)开始= = \(m\)特别小,考虑状压 设\(f[i][s]\)为第\(i\)行为\(s\)的方案数 每个棋子能攻击的只有本行,上一行, ...

  4. 【BZOJ4000】[TJOI2015]棋盘(矩阵快速幂,动态规划)

    [BZOJ4000][TJOI2015]棋盘(矩阵快速幂,动态规划) 题面 BZOJ 洛谷 题解 发现所有的东西都是从\(0\)开始编号的,所以状压只需要压一行就行了. 然后就可以随意矩乘了. #in ...

  5. BZOJ 4000: [TJOI2015]棋盘( 状压dp + 矩阵快速幂 )

    状压dp, 然后转移都是一样的, 矩阵乘法+快速幂就行啦. O(logN*2^(3m)) ------------------------------------------------------- ...

  6. [TJOI2015] 棋盘

    Description 为了提高智商,ZJY去新世界旅游了.可是旅游过后的ZJY杯具的发现要打开通往原来世界的门,必须要解开门上面画的谜题.谜题是这样的:有个\(n\)行\(m\)列的棋盘,棋盘上可以 ...

  7. 【刷题】BZOJ 4000 [TJOI2015]棋盘

    Description Input 输入数据的第一行为两个整数N,M表示棋盘大小.第二行为两个整数P,K, 表示攻击范围模板的大小,以及棋子在模板中的位置.接下来三行, 每行P个数,表示攻击范围的模版 ...

  8. [暑假的bzoj刷水记录]

    (这篇我就不信有网站来扣) 这个暑假打算刷刷题啥的 但是写博客好累啊  堆一起算了 隔一段更新一下.  7月27号之前刷的的就不写了 , 写的累 代码不贴了,可以找我要啊.. 2017.8.27upd ...

  9. TJOI2015 day2解题报告

    TJOI2015终于写完啦~~~ T1:[TJOI2015]旅游 描述:(BZ没题面只能口述了..)一个人在一棵树上走,每次从a->b会进行一次贸易(也就是在这条路径上买入物品然后在后面卖出)然 ...

随机推荐

  1. Blend操作入门: 别站在门外偷看,快进来吧!(转)

    来源:http://www.cnblogs.com/hielvis/archive/2010/10/21/1857415.html 有的人认为,Blend主要是用来修改一下颜色,调整一下布局之类的,大 ...

  2. XML约束——Schema约束

    XML Schema 也是一种用于定义和描述 XML 文档结构与内容的模式语言,其出现是为了克服 DTD 的局限性 XML Schema VS DTD: •XML Schema符合XML语法结构. • ...

  3. 初识Oracle

    登录时无法登陆:   无监听程序 ———>启动服务OracleXETNListener   监听程序当前无法识别连接描述中的请求服务————>重启服务       OracleServic ...

  4. 2013 Multi-University Training Contest 10

    HDU-4698 Counting 题意:给定一个二维平面,其中x取值为1-N,y取值为1-M,现给定K个点,问至少包括K个点中的一个的满足要求的<Xmin, Xmax, Ymin, Ymax& ...

  5. 使用Memory Analyzer tool(MAT)分析内存泄漏

    前言的前言 写blog就是好,在大前提下可以想说什么写什么,不像投稿那么字字斟酌.上周末回了趟成都办事,所以本文来迟了.K117从达州经由达成线往成都方向走的时候,发现铁路边有条河,尽管我现在也不知道 ...

  6. [转载] 单表60亿记录等大数据场景的MySQL优化和运维之道 | 高可用架构

    原文: http://mp.weixin.qq.com/s?__biz=MzAwMDU1MTE1OQ==&mid=209406532&idx=1&sn=2e9b0cc02bdd ...

  7. Python学习笔记1—模块

    模块的使用 引用模块的两种形式 形式一: import module_name 形式二: from module1 import module11   (module11是module的子模块) 例: ...

  8. Android 自定义列表指示器

    在联系人界面 可以看到这种界面 手指快速滑动右边滑动条时 可以显示相应的字母图标 android里提供了android.widget.SectionIndexer这个接口去实现该效果 可是只能显示字母 ...

  9. iOS开发之真机测试

    profile 位置在  /Users/userName/Library/MobileDevice/Provisioning Profiles /Users/user_lzz/Library/Mobi ...

  10. markdown 语法学习

    markdown是一种轻量级的标记语言,和html类似,但是易读性比html要好很多. 基本语法: 1.标题和正文分隔线 === //至少三个连续等号,最高阶标题 --- //或者三个连续的减号,第二 ...