【Luogu】P3758可乐(矩阵优化DP)
一开始想到这可能能用矩阵优化,但以为暴力就能卡过……T成二十分
首先我们回顾一下我们的暴力转移方程
用f[i][j][0/1]表示在i时刻,j点,1不爆炸,0已爆炸的方案数,那么f[i][j][0]=f[i-1][j][0]+f[i-1][j][1],f[i][j][1]=f[i-1][j][1]+f[i-1][k][1](其中k表示与j相邻的点)。
然后我们看f[i][j][1]=f[i-1][j][1]+f[i-1][k][1]这个式子
如果设定j和j相连,就化简为f[i][j][1]=f[i-1][k][1]
然后就可以用矩阵乘法啦
考虑到f[i][j][0]的求法,发现这是一个关于f[i-1][j][1]的和
而我们发现f[i-1][j][1]是一串矩阵等比数列
于是应用等比数列求和公式
#include<algorithm>
#include<cstdio>
#include<cctype>
#include<cstdlib>
#include<cstring>
#define mod 2017 inline long long read(){
long long num=,f=;
char ch=getchar();
while(!isdigit(ch)){
if(ch=='-') f=-;
ch=getchar();
}
while(isdigit(ch)){
num=num*+ch-'';
ch=getchar();
}
return num*f;
} int n,m; struct Matrix{
long long s[][];
Matrix(){memset(s,,sizeof(s)); }
Matrix operator *(const Matrix &a){
Matrix ans;
for(int i=;i<=n;++i)
for(int j=;j<=n;++j)
for(int k=;k<=n;++k)
ans.s[i][j]=(ans.s[i][j]+(s[i][k]*a.s[k][j])%mod)%mod;
return ans;
}
Matrix operator +(const Matrix &a){
Matrix ans;
for(int i=;i<=n;++i)
for(int j=;j<=n;++j)
ans.s[i][j]=(s[i][j]+a.s[i][j])%mod;
return ans;
}
}; Matrix Pow(Matrix x,int p){
Matrix ans;
for(int i=;i<=n;++i) ans.s[i][i]=;
while(p){
if(p&) ans=ans*x;
x=x*x;
p>>=;
}
return ans;
} Matrix Sum(Matrix x,int p){
Matrix ans;
if(!p) return ans;
for(int i=;i<=n;++i) ans.s[i][i]=;
ans=ans+Pow(x,p>>); ans=ans*Sum(x,p>>);
if(p&) ans=ans+Pow(x,p);
return ans;
} int q[][];
Matrix Start;
int ans; int main(){
n=read(),m=read();
for(int i=;i<=m;++i){
int from=read(),to=read();
q[from][to]=q[to][from]=;
}
for(int i=;i<=n;++i) q[i][i]=;
for(int i=;i<=n;++i)
for(int j=;j<=n;++j) Start.s[i][j]=q[i][j];
int t=read();
Matrix now; now=Pow(Start,t);
for(int i=;i<=n;++i) ans=(ans+now.s[i][])%mod;
Matrix sum; sum=Sum(Start,t -);
for(int i=;i<=n;++i) sum.s[i][i]=(sum.s[i][i]+)%mod;
for(int i=;i<=n;++i) ans=(ans+sum.s[i][])%mod;
printf("%d",ans);
return ;
}
【Luogu】P3758可乐(矩阵优化DP)的更多相关文章
- $[TJOI2017]$ 可乐 矩阵优化$dp$
\(Sol\) 设\(f_i\)为到第\(i\)秒的方案数,显然\(f_i=\)在第\(i\)秒前爆炸的方案数+在第\(i\)秒爆炸的方案数+在第\(i\)秒停下的方案数+在第\(i\)秒走向下一个城 ...
- 矩阵优化dp
链接:https://www.luogu.org/problemnew/show/P1939 题解: 矩阵优化dp模板题 搞清楚矩阵是怎么乘的构造一下矩阵就很简单了 代码: #include < ...
- bzoj 3120 矩阵优化DP
我的第一道需要程序建矩阵的矩阵优化DP. 题目可以将不同的p分开处理. 对于p==0 || p==1 直接是0或1 对于p>1,就要DP了.这里以p==3为例: 设dp[i][s1][s2][r ...
- HDU - 2294: Pendant(矩阵优化DP&前缀和)
On Saint Valentine's Day, Alex imagined to present a special pendant to his girl friend made by K ki ...
- [六省联考2017]组合数问题 (矩阵优化$dp$)
题目链接 Solution 矩阵优化 \(dp\). 题中给出的式子的意思就是: 求 nk 个物品中选出 mod k 为 r 的个数的物品的方案数. 考虑朴素 \(dp\) ,定义状态 \(f[i][ ...
- 矩阵优化DP类问题应用向小结
前言 本篇强调应用,矩阵的基本知识有所省略(也许会写篇基础向...). 思想及原理 为什么Oier们能够想到用矩阵来加速DP呢?做了一些DP题之后,我们会发现,有时候DP两两状态之间的转移是定向的,也 ...
- [Sdoi2017]序列计数 矩阵优化dp
题目 https://www.lydsy.com/JudgeOnline/problem.php?id=4818 思路 先考虑没有质数限制 dp是在同余系下的,所以\(f[i][j]\)表示前i个点, ...
- bzoj 1009 [HNOI2008]GT考试——kmp+矩阵优化dp
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1009 首先想到 确保模式串不出现 就是 确保每个位置的后缀不是该模式串. 为了dp,需要记录 ...
- 洛谷P3193 GT考试 kmp+矩阵优化dp
题意 求\(N\)位数字序列(可以有前导0)中不出现某\(M\)位子串的个数,模\(K\). \(N<=10^9,M<=20,K<=1000\) 分析 设\(dp[i][j]\)表示 ...
随机推荐
- js 字符串常用操作
function Class_String_Common(){ //将字符串 myString 的 start位置 和 end位置 之间的内容替换为 replaceStr this.replace1 ...
- ios UI自动化测试
转载:http://www.cnblogs.com/dokaygang128/p/3517674.html 一.一些注意事项: 1.做自动化测试时注意如果是真机话首先要设置不锁屏. 2.自动化测试过程 ...
- POJ 2955 Brackets (区间DP,常规)
题意: 给出一个字符串,其中仅仅含 “ ( ) [ ] ” 这4钟符号,问最长的合法符号序列有多长?(必须合法的配对,不能混搭) 思路: 区间DP的常规问题吧,还是枚举区间[i->j]再枚举其中 ...
- 一、submit和button区别
一.submit和button区别 一.HTTP方法:GET.POST
- caffe修改需要的东西
https://blog.csdn.net/zhaishengfu/article/details/51971768?locationNum=3&fps=1
- postman使用--构建工作流和newman
构建工作流 在使用“Collection Runner”的时候,集合中的请求执行顺序就是请求在Collection中的显示排列顺序.但是,有的时候我们不希望请求按照这样的方式去执行,可能是执行完第一个 ...
- iOS Crash
常见原因及解决方法: 1. 访问数组类对象越界或插入了空对象NSMutableArray/NSMutableDictionary/NSMutableSet 等类下标越界,或者 insert 了一个 n ...
- iOS开发--使用OpenSSL生成私钥和公钥的方法
最近要在新项目中使用支付宝钱包进行支付,所以要调研对接支付宝的接口,支付宝开放平台采用了RSA安全签名机制,开发者可以通过支付宝 公钥验证消息来源,同时可使用自己的私钥对信息进行加密,所以需要在本 ...
- React初识整理(一)
一.React的特点 1.自动化的UI状态管理:自动完成数据变化与界面效果的更新. 2.虚拟DOM:创建1个虚拟的dom节点树,放在内存里(内存修改数据效率高),数据变化时先修改内存里的虚拟DOM,然 ...
- 组合的输出(DFS)
题目描述: 排列与组合是常用的数学方法,其中组合就是从n个元素中抽出r个元素(不分顺序且r<=n),我们可以简单地将n个元素理解为自然数1,2,…,n,从中任取r个数. 现要求你用递归的方法输出 ...