P3990 [SHOI2013]超级跳马

题目描述

现有一个\(n\) 行 \(m\) 列的棋盘,一只马欲从棋盘的左上角跳到右下角。每一步它向右跳奇数列,且跳到本行或相邻行。跳越期间,马不能离开棋盘。

试求跳法种数\(\bmod 30011\)。

输入输出格式

输入格式:

仅有一行,包含两个正整数\(n, m\),表示棋盘的规模。

输出格式:

仅有一行,包含一个整数,即跳法种数\(\bmod 30011\)。

说明

对于\(10\%\)的数据,\(1 ≤ n ≤ 10\),\(2 ≤ m ≤ 10\);

对于\(50\%\)的数据,\(1 ≤ n ≤ 10\),\(2 ≤ m ≤ 10^5\);

对于\(80\%\)的数据,\(1 ≤ n ≤ 10\),\(2 ≤ m ≤ 10^9\);

对于\(100\%\)的数据,\(1 ≤ n ≤ 50\),\(2 ≤ m ≤ 10^9\)。


发现我的做法有点诡异...

思路:首先我们只考虑从左边某一列的转移,显然可以构造这样的一个转移矩阵

\[\begin{bmatrix}1&1&0&0&\cdots&0&0&0\\1&1&1 &0&\cdots&0&0&0\\0&1&1 &1&\cdots&0&0&0\\ \vdots&\vdots&\vdots&\vdots&\ddots&\vdots&\vdots&\vdots\\0&0&0&0&\cdots&1&1&1\\0&0&0&0&\cdots&0&1&1\end{bmatrix}
\]

然后设这个转移矩阵为\(T\),设第\(i\)列的答案矩阵为\(A_i\)

则\(A_n=T*(A_{n-1}+A_{n-3}+A_{n-5}+\dots)\)

\(A_{n-2}=T*(A_{n-3}+A_{n-5}+A_{n-7}+\dots)\)

那么有\(A_n=T*A_{n-1}+A_{n-2}\),发现这是个递推,于是再次构造矩阵加速转移

\[\begin{bmatrix}T&I\\I&O\end{bmatrix}\begin{bmatrix}A_n\\A_{n-1}\end{bmatrix}=\begin{bmatrix}A_{n+1}\\A_{n}\end{bmatrix}
\]

然后大力搞就行了,复杂度\(O(2^3n^3\log t)\)

注意一点\(A_3=TA_2\)不符合递推式


Code:

#include <cstdio>
#include <cstring>
const int mod=30011;
int n,m;
struct matrix1
{
int dx[52][52];
matrix1(){memset(dx,0,sizeof(dx));}
matrix1 friend operator *(matrix1 n1,matrix1 n2)
{
matrix1 n3;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
for(int k=1;k<=n;k++)
(n3.dx[i][j]+=n1.dx[i][k]*n2.dx[k][j])%=mod;
return n3;
}
matrix1 friend operator +(matrix1 n1,matrix1 n2)
{
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++)
(n1.dx[i][j]+=n2.dx[i][j])%=mod;
return n1;
}
};
struct matrix2
{
matrix1 dx[3][3];
matrix2(){matrix1();}
matrix2 friend operator *(matrix2 n1,matrix2 n2)
{
matrix2 n3;
for(int i=1;i<=2;i++)
for(int j=1;j<=2;j++)
for(int i1=1;i1<=n;i1++)
for(int j1=1;j1<=n;j1++)
n3.dx[i][j].dx[i1][j1]=0;
for(int i=1;i<=2;i++)
for(int j=1;j<=2;j++)
for(int k=1;k<=2;k++)
n3.dx[i][j]=n3.dx[i][j]+n1.dx[i][k]*n2.dx[k][j];
return n3;
}
}S,T,F;
int main()
{
scanf("%d%d",&n,&m);
S.dx[1][1].dx[1][1]=S.dx[1][1].dx[2][1]=1;
for(int i=1;i<=n;i++)
{
T.dx[1][2].dx[i][i]=T.dx[2][1].dx[i][i]=1;
T.dx[1][1].dx[i][i]=T.dx[1][1].dx[i][i-1]=T.dx[1][1].dx[i][i+1]=1;
}
if(m==2) return printf("%d\n",S.dx[1][1].dx[n][1]),0;
m-=3,F=T;
while(m)
{
if(m&1) F=F*T;
T=T*T;
m>>=1;
}
S=F*S;
printf("%d\n",S.dx[1][1].dx[n][1]);
return 0;
}

2018.12.19

洛谷 P3990 [SHOI2013]超级跳马 解题报告的更多相关文章

  1. [bzoj4417] [洛谷P3990] [Shoi2013] 超级跳马

    Description 现有一个n行m列的棋盘,一只马欲从棋盘的左上角跳到右下角.每一步它向右跳奇数列,且跳到本行或相邻行.跳越期间,马不能离开棋盘.例如,当n = 3, m = 10时,下图是一种可 ...

  2. 洛谷 P3989 [SHOI2013]阶乘字符串 解题报告

    P3989 [SHOI2013]阶乘字符串 题目描述 给定一个由前\(n(\le 26)\)个小写字母组成的串\(S(|S|\le 450)\).串\(S\)是阶乘字符串当且仅当前 \(n\) 个小写 ...

  3. 洛谷 P2048 [NOI2010]超级钢琴 解题报告

    P2048 [NOI2010]超级钢琴 题目描述 小Z是一个小有名气的钢琴家,最近C博士送给了小Z一架超级钢琴,小Z希望能够用这架钢琴创作出世界上最美妙的音乐. 这架超级钢琴可以弹奏出n个音符,编号为 ...

  4. 洛谷_Cx的故事_解题报告_第四题70

    1.并查集求最小生成树 Code: #include <stdio.h> #include <stdlib.h>   struct node {     long x,y,c; ...

  5. 洛谷 P2317 [HNOI2005]星际贸易 解题报告

    P2317 [HNOI2005]星际贸易 题目描述 输入输出格式 输入格式: 输出格式: 如果可以找到这样的方案,那么输出文件output.txt中包含两个整数X和Y.X表示贸易额,Y表示净利润并且两 ...

  6. 洛谷 P3802 小魔女帕琪 解题报告

    P3802 小魔女帕琪 题目背景 从前有一个聪明的小魔女帕琪,兴趣是狩猎吸血鬼. 帕琪能熟练使用七种属性(金.木.水.火.土.日.月)的魔法,除了能使用这么多种属性魔法外,她还能将两种以上属性组合,从 ...

  7. 洛谷 P2606 [ZJOI2010]排列计数 解题报告

    P2606 [ZJOI2010]排列计数 题目描述 称一个\(1,2,...,N\)的排列\(P_1,P_2...,P_n\)是\(Magic\)的,当且仅当对所以的\(2<=i<=N\) ...

  8. 洛谷1303 A*B Problem 解题报告

    洛谷1303 A*B Problem 本题地址:http://www.luogu.org/problem/show?pid=1303 题目描述 求两数的积. 输入输出格式 输入格式: 两个数 输出格式 ...

  9. 洛谷 P2604 [ZJOI2010]网络扩容 解题报告

    P2604 [ZJOI2010]网络扩容 题目描述 给定一张有向图,每条边都有一个容量C和一个扩容费用W.这里扩容费用是指将容量扩大1所需的费用.求: 1. 在不扩容的情况下,1到N的最大流: 2. ...

随机推荐

  1. python虚拟环境管理之virtualenv,virtualenvwrapper,pipenv,conda

    虚拟环境的作用 使python环境拥有独立的包,避免污染原本的python环境.为不同的项目创建不同的环境可以避免安装的库过于庞大和相互干扰. 例如你想在同一台机器上开发用python2和python ...

  2. export命令详解

    基础命令学习目录首页 export 的基本作用就是将父shell中的局部变量设置为环境变量,使得该变量可以在子shell中使用.下面设置两种情景对export进行原理解析. 情景  1. 有一个名为m ...

  3. 教你用Python解决非平衡数据问题(附代码)

    本文为你分享数据挖掘中常见的非平衡数据的处理,内容涉及到非平衡数据的解决方案和原理,以及如何使用Python这个强大的工具实现平衡的转换. 后台回复“不平衡”获取数据及代码~ 前言 好久没有更新自己写 ...

  4. 移动设备检测类Mobile_Detect.php

    移动设备检测类Mobile_Detect.php http://mobiledetect.net/ 分类:PHP 时间:2015年11月28日 Mobile_Detect.php是一个轻量级的开源移动 ...

  5. Linux下查看cpu使用率

    top命令 是Linux下常用的性能 分析工具 ,能够实时显示系统 中各个进程的资源占用状况,类似于Windows的任务管理 器.下面详细介绍它的使用方法. top - 02:53:32 up 16 ...

  6. 第一个scrim任务分布

    一.项目经理:郭健豪 二.scrim分工 杨广鑫.郭健豪:制作第一个精选页面布局,和代码实现.如:实现图书推荐布局中图书的排布,搜索框代码的实现,消息提示的跳转 李明.郑涛:实现第一个精选页面数据库的 ...

  7. Servlet 3.0 对异步处理的支持

    Servlet 3.0 实现了对异步处理的支持 通过利用注解@WebServlet(urlPatterns="/AServlet" AysnsSupported=true) 让后n ...

  8. sprint会议1

    昨天:进行第一次站立会议,讨论冲刺阶段,目标,任务认领,制作索引卡. 今天:准备查找安卓APP开发的有关资料,安装有关软件. 遇到的问题:对这方面毫无了解,不知道怎么开始,从哪开始,完全没经验.

  9. Spring笔记⑥--整合struts2

    Spring如何在web应用里面用 需要额外加入的jar包 Spring-web-4.0.0 Spring-webmvc-4.0.0 Spring的配置文件,没什么不同   需要在web.xml下配置 ...

  10. Javascript面向对象二

    Javascript面向对象二 可以通过指定原型属性来对所有的对象指定属性, Object.prototype.name="zhangsan"; Object.prototype. ...