bzoj 4000 矩阵快速幂优化DP
建立矩阵,跑快速幂
/**************************************************************
Problem: 4000
User: idy002
Language: C++
Result: Accepted
Time:32 ms
Memory:836 kb
****************************************************************/ #include <cstdio>
#include <cstring>
#define M 6 struct Matrix {
unsigned v[<<M][<<M];
const unsigned *operator[]( int i ) const { return v[i]; }
}; int n, m, p, k, bound;
int attack[];
int stat[<<M], id[<<M], stot;
Matrix base, dest; void make_unit( Matrix &x ) {
for( int i=; i<stot; i++ )
for( int j=; j<stot; j++ )
x.v[i][j] = i==j;
}
Matrix operator*( const Matrix &a, const Matrix &b ) {
Matrix c;
for( int i=; i<stot; i++ )
for( int j=; j<stot; j++ ) {
c.v[i][j] = ;
for( int k=; k<stot; k++ )
c.v[i][j] += a[i][k]*b[k][j];
}
return c;
}
Matrix mpow( Matrix a, int b ) {
Matrix rt;
for( make_unit(rt); b; b>>=,a=a*a )
if( b& ) rt=rt*a;
return rt;
}
int getarea( int s, int a ) {
int rt = ;
for( int b=; b<m; b++ ) {
if( (s>>b)& ) {
int aa = a;
if( b<k )
aa >>= k-b;
else
aa <<= b-k;
aa &= bound;
rt |= aa;
}
}
return rt;
}
void build() {
stot = ;
memset( id, -, sizeof(id) );
for( int s=; s<=bound; s++ ) {
if( getarea(s,attack[])&s ) continue;
stat[stot]=s;
id[s] = stot;
stot++;
}
for( int s1=; s1<=bound; s1++ ) {
if( id[s1]==- ) continue;
for( int s2=; s2<=bound; s2++ ) {
if( id[s2]==- ) continue;
if( getarea(s1,attack[])&s2 ) continue;
if( getarea(s2,attack[])&s1 ) continue;
base.v[id[s1]][id[s2]] = ;
}
}
}
int main() {
scanf( "%d%d%d%d", &n, &m, &p, &k );
bound = (<<m)-;
for( int i=; i<; i++ )
for( int j=,o; j<p; j++ ) {
scanf( "%d", &o );
attack[i] = attack[i] | (o<<j);
}
attack[] ^= <<k;
build();
dest = mpow( base, n- );
unsigned ans = ;
for( int i=; i<stot; i++ )
for( int j=; j<stot; j++ )
ans += dest[i][j];
printf( "%u\n", ans );
}
bzoj 4000 矩阵快速幂优化DP的更多相关文章
- 2018.10.23 bzoj1297: [SCOI2009]迷路(矩阵快速幂优化dp)
传送门 矩阵快速幂优化dp简单题. 考虑状态转移方程: f[time][u]=∑f[time−1][v]f[time][u]=\sum f[time-1][v]f[time][u]=∑f[time−1 ...
- 省选模拟赛 Problem 3. count (矩阵快速幂优化DP)
Discription DarrellDarrellDarrell 在思考一道计算题. 给你一个尺寸为 1×N1 × N1×N 的长条,你可以在上面切很多刀,要求竖直地切并且且完后每块的长度都是整数. ...
- 2018.10.22 bzoj1009: [HNOI2008]GT考试(kmp+矩阵快速幂优化dp)
传送门 f[i][j]f[i][j]f[i][j]表示从状态"匹配了前i位"转移到"匹配了前j位"的方案数. 这个东西单次是可以通过跳kmp的fail数组得到的 ...
- 2018.10.16 uoj#340. 【清华集训2017】小 Y 和恐怖的奴隶主(矩阵快速幂优化dp)
传送门 一道不错的矩阵快速幂优化dpdpdp. 设f[i][j][k][l]f[i][j][k][l]f[i][j][k][l]表示前iii轮第iii轮还有jjj个一滴血的,kkk个两滴血的,lll个 ...
- 【bzoj1009】[HNOI2008]GT考试(矩阵快速幂优化dp+kmp)
题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=1009 这道题一看数据范围:$ n<=10^9 $,显然不是数学题就是矩乘快速幂优 ...
- BZOJ 1009 [HNOI2008]GT考试(矩阵快速幂优化DP+KMP)
题意: 求长度为n的不含长为m的指定子串的字符串的个数 1s, n<=1e9, m<=50 思路: 长见识了.. 设那个指定子串为s f[i][j]表示长度为i的字符串(其中后j个字符与s ...
- LOJ2325. 「清华集训 2017」小 Y 和恐怖的奴隶主【矩阵快速幂优化DP】【倍增优化】
LINK 思路 首先是考虑怎么设计dp的状态 发现奴隶主的顺序没有影响,只有生命和个数有影响,所以就可以把每个生命值的奴隶主有多少压缩成状态就可以了 然后发现无论是什么时候一个状态到另一个状态的转移都 ...
- bzoj1009 [HNOI2008]GT考试——KMP+矩阵快速幂优化DP
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1009 字符串计数DP问题啊...连题解都看了好多好久才明白,别提自己想出来的蒟蒻我... 首 ...
- 2019.02.11 bzoj4818: [Sdoi2017]序列计数(矩阵快速幂优化dp)
传送门 题意简述:问有多少长度为n的序列,序列中的数都是不超过m的正整数,而且这n个数的和是p的倍数,且其中至少有一个数是质数,答案对201704082017040820170408取模(n≤1e9, ...
随机推荐
- SHELL (4) —— 变量的数值计算实践
摘自:Oldboy Linux运维——SHELL编程实战 利用(())双括号进行比较及判断: [root@yeebian ~]# echo $((3<8)) 1 #1表示真. [root@yee ...
- js 奇葩技巧之隐藏代码
昨天在群看到有人发了个文章叫<“短”化你的代码>,思路非常不错,采用unicode的零宽字符来实现字符隐藏,虽然有字符,可是你却看不见它.这篇文章详细的介绍了这种方法的实现原理,最后还给出 ...
- [转载] PNG优化插件:TinyPNG for Photoshop CC
http://www.im286.com/thread-14922316-1-1.html http://www.tinypng.com的PS插件版,优化.无损压缩PNG,支持批量处理,据说只支持Ph ...
- 阿里云Linux服务器挂载数据盘
步骤1.登录服务器2.检查磁盘信息 命令:fdisk -l3.磁盘分区 命令:fdisk /dev/xvdb 查看命令帮助 m n //新增一个分区 p //建立一个主分区 1 //设置盘符为1 回车 ...
- [机器学习&数据挖掘]机器学习实战决策树plotTree函数完全解析
在看机器学习实战时候,到第三章的对决策树画图的时候,有一段递归函数怎么都看不懂,因为以后想选这个方向为自己的职业导向,抱着精看的态度,对这本树进行地毯式扫描,所以就没跳过,一直卡了一天多,才差不多搞懂 ...
- cordova app 监听物理返回键
物理返回键指的是手机系统自带的返回按钮,通过cordova监听返回按钮操作,可以禁止某些页面的返回操作,以及实现点击两次返回按钮退出应用. var pageUrl = window.location. ...
- State Estimation for Robotics (Tim Barfoot) exercises Answers
Here are some exercises answers for State Estimation for Robotics, which I did in June, 2017. The bo ...
- golang container heap&sort
go语言也自己的容器数据结构.主要有list.heap和ring package main import ( "container/heap" "fmt" &q ...
- UE没法远程修改文件
UE没法远程修改文件修改ftp和sftp修改方式都没有作用,考虑可能是防火墙的作用,关闭防火墙可以.于是在控制面板->防火墙->修改策略中将UE的公用网络打开.
- 移动端console.log()调试
在微信或app进行开发的时候,没法直接查看console.log的输出内容,调试起来简直太痛苦了. 1.笨笨的方法 fiddler抓请求:追加dom节点,显示调试信息. var div =docume ...