[BZOJ]4162: shlw loves matrix II
Time Limit: 30 Sec Memory Limit: 128 MB
Description
Input
Output
Sample Input
5 9 5
5 4 0
8 8 8
Sample Output
45 61 25
144 168 104
HINT
对于 100% 数据,满足 n <= 2^10000;k <= 50; 0 <= Mij < 10^9 +7
Solution
矩阵乘法特征多项式优化,矩阵M的特征多项式是$f(\lambda)=|M-\lambda I|$,随便带入k+1个$\lambda$,高斯消元求出行列式的值,然后插值就能求出M的特征多项式(这里的总复杂度为$O(k^4)$,主要在计算行列式上面)。根据Cayley-Hamilton定理,$f(M)=0$,也就是说对同一个式子减去若干个$f(M)$后值不变,我们即可用M的k-1次多项式表示一个M的次幂,两个多项式相乘后对$f(M)$取模,然后就可以快速幂了,多项式取模和乘法用$O(k^2)$暴力就够了,总复杂度$O(k^4+k^2logn)$。
Code
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define ll long long
inline int read()
{
int x;char c;
while((c=getchar())<''||c>'');
for(x=c-'';(c=getchar())>=''&&c<='';)x=x*+c-'';
return x;
}
#define ML 10000
#define MK 50
#define MN 100
#define MOD 1000000007
char s[ML+];
int k,c[MK+][MK+],x[MK+],ans[MK+][MK+];
inline int mo1(int x){return x<MOD?x:x-MOD;}
inline int mo2(int x){return x<?x+MOD:x;}
int inv(int x)
{
int r=,y=MOD-;
for(;y;y>>=,x=1LL*x*x%MOD)if(y&)r=1LL*r*x%MOD;
return r;
}
struct poly
{
int n,a[MN+];
poly(int n=,int a0=,int a1=):n(n){memset(a,,sizeof(a));a[]=a0;a[]=a1;}
friend poly operator+(poly a,const poly&b)
{
a.n=max(a.n,b.n);
for(int i=;i<=a.n;++i)a.a[i]=mo1(a.a[i]+b.a[i]);
return a;
}
friend poly operator*(const poly&a,const poly&b)
{
poly c(a.n+b.n);int i,j;ll x;
for(i=;i<=c.n;c.a[i++]=x%MOD)for(x=j=;j<=i&&j<=a.n;++j)
x+=1LL*a.a[j]*b.a[i-j],x>8e18?x%=MOD:;
return c;
}
friend poly operator*(poly a,int b)
{
for(int i=;i<=a.n;++i)a.a[i]=1LL*a.a[i]*b%MOD;
return a;
}
friend poly operator/(poly a,const poly&b)
{
poly c(a.n-b.n);int i,j;
for(i=a.n;i>=b.n;--i)
{
c.a[i-b.n]=1LL*a.a[i]*inv(b.a[b.n])%MOD;
for(j=;j<=b.n;++j)a.a[i-j]=mo2((a.a[i-j]-1LL*b.a[b.n-j]*c.a[i-b.n])%MOD);
}
return c;
}
friend poly operator%(poly a,const poly&b)
{
int i,j,x;
for(i=a.n;i>=b.n;--i)
{
x=1LL*a.a[i]*inv(b.a[b.n])%MOD;
for(j=;j<=b.n;++j)a.a[i-j]=mo2((a.a[i-j]-1LL*b.a[b.n-j]*x)%MOD);
}
a.n=b.n-;
return a;
}
}f,a,p(,);
struct mat
{
int z[MK+][MK+];
mat(){memset(z,,sizeof(z));}
friend mat operator*(const mat&a,const mat&b)
{
mat c;int i,j,k;ll x;
for(i=;i<=MK;++i)for(j=;j<=MK;c.z[i][j++]=x%MOD)
for(x=k=;k<=MK;++k)x+=1LL*a.z[i][k]*b.z[k][j],x>8e18?x%=MOD:;
return c;
}
}m,n;
int cal(int x)
{
int i,j,l,ans=;
for(i=;i<=k;++i)for(j=;j<=k;++j)c[i][j]=m.z[i][j];
for(i=;i<=k;++i)c[i][i]=mo2(c[i][i]-x);
for(i=;i<=k;++i)
{
for(j=i;j<=k;++j)if(c[j][i])break;
if(j>k)return ;
if(j>i)for(ans=MOD-ans,l=i;l<=k;++l)swap(c[i][l],c[j][l]);
ans=1LL*ans*c[i][i]%MOD;
for(j=i;++j<=k;)
{
x=1LL*c[j][i]*inv(c[i][i])%MOD;
for(l=i;l<=k;++l)c[j][l]=mo2((c[j][l]-1LL*c[i][l]*x)%MOD);
}
}
return ans;
}
int main()
{
int i,j,l,v;
scanf("%s",s+);k=read();
for(i=;i<=k;++i)for(j=;j<=k;++j)m.z[i][j]=read();
for(i=;i<=k;++i)x[i]=cal(i);
for(i=;i<=k;++i)p=p*poly(,mo2(-i),);
for(i=;i<=k;++i)
{
for(v=x[i],j=;j<=k;++j)if(i!=j)v=1LL*v*inv(mo2(i-j))%MOD;
f=f+p/poly(,mo2(-i),)*v;
}
a=poly(,);p=poly(,,);
for(i=strlen(s+);i;--i,p=p*p%f)if(s[i]>'')a=a*p%f;
for(i=;i<=k;++i)n.z[i][i]=;
for(l=;l<k;++l,n=n*m)for(i=;i<=k;++i)for(j=;j<=k;++j)
ans[i][j]=(ans[i][j]+1LL*a.a[l]*n.z[i][j])%MOD;
for(i=;i<=k;printf("%d\n",ans[i++][j]))for(j=;j<k;++j)printf("%d ",ans[i][j]);
}
[BZOJ]4162: shlw loves matrix II的更多相关文章
- [bzoj4162]shlw loves matrix II
来自FallDream的博客,未经允许,请勿转载,谢谢 给定矩阵k*k的矩阵M,请计算 M^n,并将其中每一个元素对 1000000007 取模输出. k<=50 n<=2^10000 考 ...
- BZOJ4162:shlw loves matrix II
传送门 利用Cayley-Hamilton定理,用插值法求出特征多项式 \(P(x)\) 然后 \(M^n\equiv M^n(mod~P(x))(mod~P(x))\) 然后就多项式快速幂+取模 最 ...
- bzoj 3462: DZY Loves Math II
3462: DZY Loves Math II Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 211 Solved: 103[Submit][Sta ...
- bzoj 4161 Shlw loves matrixI——常系数线性齐次递推
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4161 还是不能理解矩阵…… 关于不用矩阵理解的方法:https://blog.csdn.ne ...
- BZOJ 3569 DZY Loves Chinese II
Description 神校XJ之学霸兮,Dzy皇考曰JC. 摄提贞于孟陬兮,惟庚寅Dzy以降. 纷Dzy既有此内美兮,又重之以修能. 遂降临于OI界,欲以神力而凌♂辱众生. 今Dzy有一魞歄图,其上 ...
- BZOJ 3569: DZY Loves Chinese II [高斯消元XOR 神题]
http://www.lydsy.com/JudgeOnline/problem.php?id=3569 题意:多次询问一个无向连通图当图中某k条边消失时这个图是否联通 强制在线 太神啦啦啦啦啦啦啦啦 ...
- [bzoj4161]Shlw loves matrix I
来自FallDream的博客,未经允许,请勿转载,谢谢. 给定数列 {hn}前k项,其后每一项满足 hn = a1*h(n-1) + a2*h(n-2) + ... + ak*h(n-k) 其中 a1 ...
- bzoj 4161: Shlw loves matrixI
Description 给定数列 {hn}前k项,其后每一项满足 hn = a1h(n-1) + a2h(n-2) + ... + ak*h(n-k) 其中 a1,a2...ak 为给定数列.请计算 ...
- BZOJ 3569 DZY Loves Chinese II 树上差分+线性基
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3569 Description 神校XJ之学霸兮,Dzy皇考曰JC. 摄提贞于孟陬兮,惟庚寅 ...
随机推荐
- 2017-2018-1 20155306 《信息安全系统设计基础》Mybash的实现
2017-2018-1 20155306 <信息安全系统设计基础>Mybash的实现 要求: 使用fork,exec,wait实现mybash 写出伪代码,产品代码和测试代码 发表知识理解 ...
- tornado 采用 epoll 代理构建高并发网络模型
1 阻塞和非阻塞 对于阻塞和非阻塞,网上有一个很形象的比喻,就是说好比你在等快递,阻塞模式就是快递如果不到,你就不能做其他事情.非阻塞模式就是在这段时间里面,你可以做其他事情,比如上网.打游戏.睡觉 ...
- 使用XIB的UITableViewCell自适应,以及出现的问题进行解决
1.首先需要定义一个属性 @property (nonatomic, strong) UITableViewCell *prototypeCell; 2.在创建完tableView后加上如下代码 se ...
- bzoj千题计划271:bzoj4869: [六省联考2017]相逢是问候
http://www.lydsy.com/JudgeOnline/problem.php?id=4869 欧拉降幂+线段树,每个数最多降log次,模数就会降为1 #include<cmath&g ...
- python hashlib、hmac模块
一.hashlib模块 import hashlib m = hashlib.md5() m.update(b"Hello") print(m.hexdigest()) m.upd ...
- AngularJS1.X学习笔记8-自定义指令(上)
AngulaJS的指令是一种非常强大的特性,一个ng-repeat就能让我们非常方便的展示一个数据列表,指令相当于是一个组件,为我们将一些东西封装起来了,提供了复用的可能性.个人认为自定义指令还是比较 ...
- 图数据库orientDB(1-1)SQL基本操作
SQL基本操作 1.新增VerTex CREATE VERTEX V SET name="user01",sex="M",age="25"; ...
- ELK学习总结(3-1)elk的基本查询
基本查询:内置条件 组合查询:组合基本查询 过滤:查询同时,通过filter筛选数据 准备工作 GET /library/books/_mget { "ids":["1 ...
- BlueMix - IBM的Paas云计算平台
Bluemix,2015年年中,IBM推出了名为Bluemix的云计算平台.这一"平台即服务"的PaaS云将帮助开发者更快的进行应用开发和部署. Bluemix正是IBM回应这 ...
- 阿里云API网关(9)常见问题
网关指南: https://help.aliyun.com/document_detail/29487.html?spm=5176.doc48835.6.550.23Oqbl 网关控制台: https ...