本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作。

本文作者:ljh2000
作者博客:http://www.cnblogs.com/ljh2000-jump/
转载请注明出处,侵权必究,保留最终解释权!

Description

婷婷是个喜欢矩阵的小朋友,有一天她想用电脑生成一个巨大的n行m列的矩阵(你不用担心她如何存储)。她生成的这个矩阵满足一个神奇的性质:若用F[i][j]来表示矩阵中第i行第j列的元素,则F[i][j]满足下面的递推式:

F[1][1]=1
F[i,j]=a*F[i][j-1]+b (j!=1)
F[i,1]=c*F[i-1][m]+d (i!=1)
递推式中a,b,c,d都是给定的常数。

现在婷婷想知道F[n][m]的值是多少,请你帮助她。由于最终结果可能很大,你只需要输出F[n][m]除以1,000,000,007的余数。

本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作。

Input

一行有六个整数n,m,a,b,c,d。意义如题所述

Output

包含一个整数,表示F[n][m]除以1,000,000,007的余数

Sample Input

3 4 1 3 2 6

Sample Output

85

HINT

样例中的矩阵为:

1 4 7 10

26 29 32 35

76 79 82 85

1<=N,M<=10^1000 000,a<=a,b,c,d<=10^9

正解:费马小定理+快速幂+递推公式

解题报告:

  大多数题解写的都是矩乘+快速幂的,感觉不用那么麻烦,只需要一点点高一课堂上讲过的推出递推式子就可以了。

  推导过程其实挺简单的,就是根据那个式子,先推导出f[i,m]和f[i,1]的关系,然后得到f[i+1,1],再根据新的式子得到f[n+1,1]和f[1,1]的关系,反推得到f[n,m]即可。

  具体推导的话直接复制别人的了,很详细:(参考博客链接:http://www.cnblogs.com/iiyiyi/p/5617598.html)

 //It is made by ljh2000
#include <iostream>
#include <cstdlib>
#include <cstring>
#include <cstdio>
#include <cmath>
#include <algorithm>
#include <ctime>
#include <vector>
#include <queue>
#include <map>
#include <set>
using namespace std;
typedef long long LL;
const int inf = (<<);
const int MAXN = ;
const int mod = ;
const int MOD = ;
int n,m,len;
int k1[],k2[];
int mi[]={,,,,,,,,};
char ch[MAXN];
LL a,b,c,d,A,B,ans,ans2,C,D;
//A=c*a^(m-1)
//B=( ( b*c*(a^(m-1)-1) ) / (a-1) )+d inline int getint()
{
int w=,q=; char c=getchar();
while((c<'' || c>'') && c!='-') c=getchar(); if(c=='-') q=,c=getchar();
while (c>='' && c<='') w=w*+c-'', c=getchar(); return q ? -w : w;
}
inline LL fastpow(LL x,LL y){
if(x== || y==) return ;
LL base=x,r=;
while(y>) {
if(y&) r*=base,r%=mod;
base*=base; base%=mod; y>>=;
}
return r;
}
inline LL ni(LL x){ return fastpow(x,mod-); }
inline LL fastpow_m(){
LL res=; LL mm=;//对指数取模
for(int i=;i<=m;i++) res+=mm*k2[i]%(mod-),mm*=MOD,mm%=(mod-),res%=(mod-);
return fastpow(a,res);
/*
LL r=1,base=a;
while(m) {
if(k2[1]&1) r*=base,r%=mod;
base*=base; base%=mod;
for(int i=m;i>=1;i--) {
if(k2[i]&1) k2[i-1]+=MOD;
k2[i]>>=1;
}
while(k2[m]==0 && m>0) m--;
}
return r;*/
} inline LL fastpow_n(LL di){
LL res=; LL mm=;//对指数取模
for(int i=;i<=n;i++) res+=mm*k1[i]%(mod-),mm*=MOD,mm%=(mod-),res%=(mod-);
return fastpow(di,res);
/*
LL r=1,base=di;
while(n) {
if(k1[1]&1) r*=base,r%=mod;
base*=base; base%=mod;
for(int i=n;i>=1;i--) {
if(k1[i]&1) k1[i-1]+=MOD;
k1[i]>>=1;
}
while(k1[n]==0 && n>0) n--;
}
return r;*/
} inline void getAB(){
A=fastpow_m(); A*=ni(a); A%=mod; //A=a^(m-1)
B=A; B--; B*=b; B%=mod; B*=c; B%=mod;
B*=ni(a-); B%=mod; B+=d; B%=mod; A*=c; A%=mod;
} inline void over(){
ans-=d; ans+=mod; ans%=mod; ans*=ni(c); ans%=mod;
printf("%lld",ans);
} inline void work(){
scanf("%s",ch); len=strlen(ch); n=; int now=;
int gi=;
for(int i=len-;i>=;i--) {
now=now+(ch[i]-'')*mi[gi];//!!!
gi++;
if(now>=MOD || gi>=) {
gi=;//!!!
k1[n]+=now%MOD;
k1[++n]=now/MOD;
now=;//!!!
}
}
k1[n]+=now; while(k1[n]==) n--; scanf("%s",ch); len=strlen(ch); m=; now=;
gi=;
for(int i=len-;i>=;i--) {
now=now+(ch[i]-'')*mi[gi]; gi++;
if(now>=MOD || gi>=) {
gi=;
k2[m]+=now%MOD;
k2[++m]=now/MOD;
now=;
}
}
k2[m]+=now; while(k2[m]==) m--;
a=getint(); b=getint(); c=getint(); d=getint();
if(a!=) {
getAB();
if(A!=) {
ans=fastpow_n(A); ans%=mod;
ans2=ans-; ans2+=mod; ans2%=mod; ans2*=B; ans2%=mod;
ans2*=ni(A-); ans2%=mod; ans+=ans2; ans%=mod;
}
else{//特判A==1
LL res=,mm=; for(int i=;i<=n;i++) res+=mm*k1[i]%mod,mm*=MOD,mm%=mod,res%=mod;
ans=res*B; ans++; ans%=mod;
}
over();
}
else {
D=c*b; D%=mod; LL res=,mm=;
for(int i=;i<=m;i++) res+=mm*k2[i]%mod,mm*=MOD,mm%=mod,res%=mod;
res--; res+=mod; res%=mod; D*=res; D%=mod; D+=d; D%=mod;
if(c==) {
res=; mm=; for(int i=;i<=n;i++) res+=mm*k1[i]%mod,mm*=MOD,mm%=mod,res%=mod;
D*=res; D%=mod; ans=D+;
over();
}
else{
C=fastpow_n(c);
ans=C; C-=; C*=ni(c-); C%=mod;
ans+=D*C; ans%=mod;
over();
}
}
} int main()
{
work();
return ;
}

BZOJ3240 [Noi2013]矩阵游戏的更多相关文章

  1. BZOJ3240 [Noi2013]矩阵游戏 矩阵 快速幂 卡常

    原文链接http://www.cnblogs.com/zhouzhendong/p/8084891.html 题目传送门 - BZOJ3240 题意概括 F[1][1]=1F[i,j]=a*F[i][ ...

  2. BZOJ3240 NOI2013矩阵游戏(数论)

    必修五题. // luogu-judger-enable-o2 #include<iostream> #include<cstdio> #include<cmath> ...

  3. 题解【bzoj3240 [NOI2013]矩阵游戏】

    挖坑2333 等我把代码写完了再写

  4. bzoj3240 [Noi2013]矩阵游戏——费马小定理+推式子

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3240 n 和 m 太过巨大,不难想到应该用费马小定理什么的来缩小范围: 总之就是推式子啦,看 ...

  5. bzoj 3240: [Noi2013]矩阵游戏 矩阵乘法+十进制快速幂+常数优化

    3240: [Noi2013]矩阵游戏 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 613  Solved: 256[Submit][Status] ...

  6. BZOJ 3240: [Noi2013]矩阵游戏

    3240: [Noi2013]矩阵游戏 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1586  Solved: 698[Submit][Status ...

  7. BZOJ 3240([Noi2013]矩阵游戏-费马小定理【矩阵推论】-%*s-快速读入)

    3240: [Noi2013]矩阵游戏 Time Limit: 10 Sec   Memory Limit: 256 MB Submit: 123   Solved: 73 [ Submit][ St ...

  8. (十进制高速幂+矩阵优化)BZOJ 3240 3240: [Noi2013]矩阵游戏

    题目链接: http://www.lydsy.com/JudgeOnline/problem.php?id=3240 3240: [Noi2013]矩阵游戏 Time Limit: 10 Sec  M ...

  9. P1397 [NOI2013]矩阵游戏(递推)

    P1397 [NOI2013]矩阵游戏 一波化式子,$f[1][m]=a^{m-1}+b\sum_{i=0}^{m-2}a^i$,用快速幂+逆元求等比数列可以做到$logm$ 设$v=a^{m-1}, ...

随机推荐

  1. 043医疗项目-模块四:采购单模块—采购单明细查询(Dao,Service,Action三层)

    前一篇文章我们做的是在医院的角度上添加在采购单里面添加药品.这一篇文章是查看我们添加的采购单信息. 我们先看一下要实现的效果:当: 按下确认添加时,会在这里 显示出刚才添加的数据. 好,我们就来做这个 ...

  2. BZOJ 4003 【JLOI2015】城池攻占

    Description 小铭铭最近获得了一副新的桌游,游戏中需要用 m 个骑士攻占 n 个城池. 这 n 个城池用 1 到 n 的整数表示.除 1 号城池外,城池 i 会受到另一座城池 fi 的管辖, ...

  3. How To Create an IE-Only Stylesheet

    https://css-tricks.com/how-to-create-an-ie-only-stylesheet/ https://css-tricks.com/snippets/css/css- ...

  4. 清北学堂2017NOIP冬令营入学测试P4747 D’s problem(d)

    时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试题 描述 题目描述 小D是一名魔法师,它最喜欢干的事就是对批判记者了. 这次记者招待会上,记者对 ...

  5. ubuntu15.10 或者 16.04 或者 ElementryOS 下使用 Dotnet Core

    这里我们不讲安装,缺少libicu52自行安装. 安装完成后使用dotnet restore或者build都会失败,一是报编译的dll不适合当前系统,二是编译到ubuntu16.04文件夹下会产生一些 ...

  6. 前端见微知著番外篇:GIT舍我其谁?

    在上一篇中,我们讲到了利用纯UI的软件如何实现代码的提交.但是在MAC机器上,是没有turtoiseGit这类软件的,所以利用命令行的方式就是我们的首选了. 下面我们来描述两种主要的Git使用场景: ...

  7. c#邮件发送的实现

    第一步 :引用命名空间 using System.Net; using System.Net.Mail; 第二步:具体代码 //创建邮箱信息 MailMessage myMail = new Mail ...

  8. php基础入门

    一.序言 由于新公司的需要,我也就从原来的asp专向了,php的学习中.希望通过自己的学习能够尽快的熟悉了解php 二.php独特的语法特色  1.引号问题 在php中单引号和双引号的作用基本相同,但 ...

  9. 准标识符(Quasi-dientifier, QI)

    Quasi-identifier From Wikipedia, the free encyclopedia Quasi-identifiers are pieces of information t ...

  10. 用SpringMvc实现Excel导出功能

    以前只知道用poi导出Excel,最近用了SpringMvc的Excel导出功能,结合jxl和poi实现,的确比只用Poi好,两种实现方式如下: 一.结合jxl实现: 1.引入jxl的所需jar包: ...