题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3231

裸矩阵乘法。

代码如下:

#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
typedef long long ll;
ll K,b[],c[],m,n,p,ans1,ans2,s[];
struct Matrix{
ll a[][];
Matrix(){memset(a,,sizeof a);}
void init(){for(int i=;i<=K+;i++)a[i][i]=;}
Matrix operator * (const Matrix &y) const
{
Matrix ret;
for(int i=;i<=K+;i++)
for(int k=;k<=K+;k++)
for(int j=;j<=K+;j++)
(ret.a[i][j]+=a[i][k]*y.a[k][j])%=p;
return ret;
}
}f,g;
Matrix pw(Matrix a,ll b)
{
Matrix ret; ret.init();
for(;b;b>>=1ll,a=a*a)
if(b&)ret=ret*a;
return ret;
}
void print(Matrix x)
{
for(int i=;i<=K+;i++)
{
for(int j=;j<=K+;j++)
printf("%d",x.a[i][j]);
printf("\n");
}
}
int main()
{
scanf("%lld",&K);
for(int i=;i<=K;i++)scanf("%lld",&b[i]),f.a[][i]=b[i],s[i]=s[i-]+b[i];
f.a[][K+]=s[K-];
for(int i=;i<=K;i++)scanf("%lld",&c[i]);
scanf("%lld%lld%lld",&m,&n,&p);
for(int i=;i<K;i++)g.a[i+][i]=;
for(int i=;i<=K;i++)g.a[i][K]=c[K-i+];
g.a[K][K+]=g.a[K+][K+]=;
if(n<=K)ans1=s[n]%p;
else
{
Matrix aa=f*pw(g,n-K+);
ans1=aa.a[][K+];
}
if(m-<=K)ans2=s[m-]%p;
else
{
Matrix aa=f*pw(g,m-K);
ans2=aa.a[][K+];
}
printf("%lld\n",((ans1-ans2)%p+p)%p);//
return ;
}

bzoj 3231 [ Sdoi 2008 ] 递归数列 —— 矩阵乘法的更多相关文章

  1. bzoj 3231 [Sdoi2008]递归数列——矩阵乘法

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3231 矩阵乘法裸题. 1018是10^18.别忘了开long long. #include& ...

  2. [bzoj3231][SDOI2008]递归数列——矩阵乘法

    题目大意: 一个由自然数组成的数列按下式定义: 对于i <= k:ai = bi 对于i > k: ai = c1ai-1 + c2ai-2 + ... + ckai-k 其中bj和 cj ...

  3. 【bzoj3231】[Sdoi2008]递归数列 矩阵乘法+快速幂

    题目描述 一个由自然数组成的数列按下式定义: 对于i <= k:ai = bi 对于i > k: ai = c1ai-1 + c2ai-2 + ... + ckai-k 其中bj和 cj  ...

  4. [luogu2461 SDOI2008] 递归数列 (矩阵乘法)

    传送门 Description 一个由自然数组成的数列按下式定义: 对于i <= k:ai = bi 对于i > k: ai = c1ai-1 + c2ai-2 + ... + ckai- ...

  5. P2461 [SDOI2008]递归数列 矩阵乘法+构造

    还好$QwQ$ 思路:矩阵快速幂 提交:1次 题解: 如图: 注意$n,m$如果小于$k$就不要快速幂了,直接算就行... #include<cstdio> #include<ios ...

  6. 斐波那契数列 矩阵乘法优化DP

    斐波那契数列 矩阵乘法优化DP 求\(f(n) \%1000000007​\),\(n\le 10^{18}​\) 矩阵乘法:\(i\times k\)的矩阵\(A\)乘\(k\times j\)的矩 ...

  7. BZOJ 3231: [Sdoi2008]递归数列( 矩阵快速幂 )

    矩阵乘法裸题..差分一下然后用矩阵乘法+快速幂就可以了. ----------------------------------------------------------------------- ...

  8. BZOJ-3231 递归数列 矩阵连乘+快速幂

    题不是很难,但是啊,人很傻啊...机子也很鬼畜啊... 3231: [Sdoi2008]递归数列 Time Limit: 1 Sec Memory Limit: 256 MB Submit: 569 ...

  9. [BZOJ 2326] [HNOI2011] 数学作业 【矩阵乘法】

    题目链接:BZOJ - 2326 题目分析 数据范围达到了 10^18 ,显然需要矩阵乘法了! 可以发现,向数字尾部添加一个数字 x 的过程就是 Num = Num * 10^k + x .其中 k ...

随机推荐

  1. MySQL 执行计划中Extra的浅薄理解

    1.using where: Extra中出现“Using where”,通常来说,意味着全表扫描或者在查找使用索引的情况下,但是还有查询条件不在索引字段当中. 如果需要回表也是用这个. 2.usin ...

  2. 移动web——touch事件介绍

    基本概念 1.在移动web端点击事件或者滑动屏幕.捏合等动作都是由touchstar.touchmove.touchend这三个事件组合在一起使用的 2.click事件在移动端会有0.2秒的延迟,下面 ...

  3. ipc (进程间通信

    进程间通信(IPC,Inter-Process Communication),指至少两个进程或线程间传送数据或信号的一些技术或方法.进程是计算机系统分配资源的最小单位(严格说来是线程).每个进程都有自 ...

  4. .mm c++ oc 混编

    When you create a static library you don't link in the dependent libraries. As a result, when you re ...

  5. C# 获取当年的周六周日

    public void GetWMDay() { List<string> list = new List<string>(); "; DateTime counYe ...

  6. DateTimePicker 控件置空

    dtOrderDateFrom.Format = DateTimePickerFormat.Custom; dtOrderDateFrom.CustomFormat = " "; ...

  7. 使用CSS3实现表格隔行/隔列变色

    <!DOCTYPE html><html><head> <meta charset="utf-8" /> <title> ...

  8. mysql5.7初始化密码报错ERROR1820(HY000):YoumustresetyourpasswordusingALTERUSERstateme

    1,mysql5.6是密码为空直接进入数据库的,但是mysql5.7就需要初始密码 cat /var/log/mysqld.log | grep password 或者:grep 'temporary ...

  9. vue项目的路由配置

    方案一.在生成项目的时候就选择安装路由; 这个地方选择y即可; 生成项目之后在src目录下会有router文件夹,里面有index.js,并且里面已经存在一个helloWorld页面了,可以直接模仿着 ...

  10. 洛谷——P1613 跑路

    P1613 跑路 题目大意: 小A的工作不仅繁琐,更有苛刻的规定,要求小A每天早上在6:00之前到达公司,否则这个月工资清零.可是小A偏偏又有赖床的坏毛病.于是为了保住自己的工资,小A买了一个十分牛B ...