hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)

时间:2022-11-06 13:53:42

#1143 : 骨牌覆盖问题·一

时间限制:10000ms
单点时限:1000ms
内存限制:256MB

描述

骨牌,一种古老的玩具。今天我们要研究的是骨牌的覆盖问题:
我们有一个2xN的长条形棋盘,然后用1x2的骨牌去覆盖整个棋盘。对于这个棋盘,一共有多少种不同的覆盖方法呢?
举个例子,对于长度为1到3的棋盘,我们有下面几种覆盖方式:

hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)

提示:骨牌覆盖

提示:如何快速计算结果

输入

第1行:1个整数N。表示棋盘长度。1≤N≤100,000,000

输出

第1行:1个整数,表示覆盖方案数 MOD 19999997

样例输入
62247088
样例输出
17748018

解题思路:
仔细观察可以看出是Fibonacci函数 f(n)=f(n-1)+f(n-2)。
但当n特别大的时候,运算次数太多,必然超时。
所以引入:
斐波那契数列,快速矩阵幂解法。

当N很小的时候,我们直接通过递推公式便可以计算。当N很大的时候,只要我们的电脑足够好,我们仍然可以直接通过递推公式来计算。
但是我们学算法的,总是这样直接枚举不是显得很Low么,所以我们要用一个好的算法来加速(装X)。
事实上,对于这种线性递推式,我们可以用矩阵乘法来求第n项。对于本题Fibonacci数列,我们希望找到一个2x2的矩阵M,使得(a, b) x M = (b, a+b),其中(a, b)和(b, a+b)都是1x2的矩阵。
显然,只需要取M = [0, 1; 1, 1]就可以了:

hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)

进一步得到:

hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)

那么接下来的问题是,能不能快速的计算出M^n?我们先来分析一下幂运算。由于乘法是满足结合律的,所以我们有:

hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)

不妨将k[1]..k[j]划分的更好一点?

hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)

其中(k[1],k[2]...k[j])2表示将n表示成二进制数后每一位的数字。上面这个公式同时满足这样一个性质:

hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)

结合这两者我们可以得到一个算法:
1. 先计算出所有的{a^1, a^2, a^4 ... a^(2^j)},因为该数列满足递推公式,时间复杂度为O(logN)
2. 将指数n二进制化,再利用公式将对应的a^j相乘计算出a^n,时间复杂度仍然为O(logN)
则总的时间复杂度为O(logN)
这种算法因为能够在很短时间内求出幂,我们称之为“快速幂”算法。 AC代码:
 #include"iostream"
#define MOD 19999997
using namespace std; typedef long long LL; struct Matrix
{
LL matrix[][];
}ans,base; Matrix mult(Matrix a,Matrix b)
{
Matrix c;
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
c.matrix[i][j] = ;
for (int k = ; k < ; k++)
{
c.matrix[i][j] += (a.matrix[i][k] * b.matrix[k][j]) % MOD;
}
c.matrix[i][j] %= MOD;
}
} return c;
} LL solve(LL n)
{
base.matrix[][] = base.matrix[][] = base.matrix[][] = ;
base.matrix[][] = ; //初始化单位矩阵
ans.matrix[][] = ans.matrix[][] = ;
ans.matrix[][] = ans.matrix[][] = ; while (n)
{
if (n & )
{
ans = mult(ans, base);
//break;
}
base = mult(base, base);
n >>= ; //n右移一位,n=n>>1 n/2 }
return ans.matrix[][] % MOD; } int main()
{
LL n;
scanf("%lld", &n); printf("%lld", solve(n+) % MOD);
system("pause");
}

hiho #1143 : 骨牌覆盖问题·一 (运用快速幂矩阵)的更多相关文章

  1. hihoCoder 1143 &colon; 骨牌覆盖问题&&num;183&semi;一&lpar;递推,矩阵快速幂&rpar;

    [题目链接]:click here~~ 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 骨牌,一种古老的玩具.今天我们要研究的是骨牌的覆盖问题: 我们有一个2xN的长条形 ...

  2. hihoCoder &num;1143 &colon; 骨牌覆盖问题&&num;183&semi;一

    #1143 : 骨牌覆盖问题·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 骨牌,一种古老的玩具.今天我们要研究的是骨牌的覆盖问题:我们有一个2xN的长条形棋盘,然 ...

  3. hihoCoder &num;1143 &colon; 骨牌覆盖问题&CenterDot;一&lpar;矩阵乘法&rpar;

    1143 : 骨牌覆盖问题·一 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 骨牌,一种古老的玩具.今天我们要研究的是骨牌的覆盖问题: 我们有一个2xN的长条形棋盘,然 ...

  4. 矩阵乘法&amp&semi;矩阵快速幂&amp&semi;矩阵快速幂解决线性递推式

    矩阵乘法,顾名思义矩阵与矩阵相乘, 两矩阵可相乘的前提:第一个矩阵的行与第二个矩阵的列相等 相乘原则: a b     *     A B   =   a*A+b*C  a*c+b*D c d     ...

  5. hdu&lowbar;2604Queuing&lpar;快速幂矩阵&rpar;

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2604 Queuing Time Limit: 10000/5000 MS (Java/Others)  ...

  6. Number Sequence&lpar;快速幂矩阵)

    题目连接:http://acm.hdu.edu.cn/showproblem.php?pid=1005 Number Sequence Time Limit: 2000/1000 MS (Java/O ...

  7. 【bzoj4870】&lbrack;Shoi2017&rsqb;组合数问题 dp&plus;快速幂&sol;矩阵乘法

    题目描述 输入 第一行有四个整数 n, p, k, r,所有整数含义见问题描述. 1 ≤ n ≤ 10^9, 0 ≤ r < k ≤ 50, 2 ≤ p ≤ 2^30 − 1 输出 一行一个整数 ...

  8. 快速幂 &amp&semi; 矩阵快速幂

    目录 快速幂 实数快速幂 矩阵快速幂 快速幂 实数快速幂 普通求幂的方法为 O(n) .在一些要求比较严格的题目上很有可能会超时.所以下面来介绍一下快速幂. 快速幂的思想其实是将数分解,即a^b可以分 ...

  9. hihoCoder &num;1143 &colon; 骨牌覆盖问题&&num;183&semi;一 (斐波那契数列)

    题意:我们有一个2xN的长条形棋盘,然后用1x2的骨牌去覆盖整个棋盘.对于这个棋盘,一共有多少种不同的覆盖方法呢? 思路:这是斐波那契数列啊,f[n] = f[n-1] + f[n-2],初始时 f[ ...

随机推荐

  1. 解决tkinter在windows上没有正确安装的问题

    问题 Can't find a usable tk.tcl in the following directories: 解决方法 加两个环境变量,在我的机器上是这样的 TCL_LIBRARY=D:\d ...

  2. 【java】 java 实现mysql备份

    使用java实现mysql的备份: public class MySQLBackUp { /** * Java代码实现MySQL数据库导出 * * @author GaoHuanjie * @para ...

  3. Css 描点

    <!DOCTYPE HTML> <html lang="en-US"> <head> <meta charset="UTF-8& ...

  4. VMware中linux与window目录共享

    在虚拟机下来实如今windows下共享一个目录: (前提已安装完毕vmtools:http://blog.csdn.net/pipisorry/article/details/21318931) 打开 ...

  5. iOS7 初体验

    iOS7 初体验 近日来由于iOS7的发布,引来业界的各种吐槽. 为了体验一把,我已经把iPhone5刷成了iOS7,也下载Xcode5-DP并进行了测试.我想说的是iOS7与Xcode5-DP中新增 ...

  6. P3312 &lbrack;SDOI2014&rsqb;数表

    啊啊啊我昨天怎么没写题解wwww 补昨日题解... 题目链接 : https://www.luogu.org/problemnew/show/P3312 也是莫反 我要把fft留到今天写 [和zyn小 ...

  7. 学习Spring Boot:(十四)spring-shiro的密码加密

    前言 前面配置了怎么使用 shiro ,这次研究下怎么使用spring shiro的密码加密,并且需要在新增.更新用户的时候,实现生成盐,加密后的密码进行入库操作. 正文 配置凭证匹配器 @Bean ...

  8. debian中添加sudo命令

    解决方法(root命令) apt-get install sudochmod u+w /etc/sudoers //给此文件增加写入权限gedit /etc/sudoers找到root ALL=(AL ...

  9. Canvas坐标轴中的Y轴距离是X轴的两倍

    如题,相信很多人在初次玩canvas的时候会出现这样的情况,跟着教程走的情况下,诶 怎么画出来的东西,不怎么对劲啊,,,ԾㅂԾ,,!!!!!先上代码 <!DOCTYPE html> &lt ...

  10. 一步一步学Silverlight 2系列文章

    概述 由TerryLee编写的<Silverlight 2完美征程>一书,已经上市,在该系列文章的基础上补充了大量的内容,敬请关注.官方网站:http://www.dotneteye.cn ...