我们先不妨看一道题:
看见n的数据范围就知道直接按以前的递归写肯定狗带,那我们有什么其他的方法吗?
下面是分析:
我们就拿斐波那契数列试试手吧:
下面是AC代码,可以当作模板记:
#include<bits/stdc++.h>
using namespace std;
#define int long long
int m,n,mod=1e9+7;
struct node{
int m[100][100];
}ans,res;
node mul(node a,node b){
node tmp;
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
tmp.m[i][j]=0;
}
}
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
for(int k=0;k<n;k++){
tmp.m[i][j]=(tmp.m[i][j]+a.m[i][k]*b.m[k][j])%mod;
}
}
}
return tmp;
}
void quickpower(int m,int n){
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
if(i==j) ans.m[i][j]=1;
else ans.m[i][j]=0;
}
}
while(m){
if(m&1) ans=mul(ans,res);
res=mul(res,res);
m=m>>1;
}
}
signed main(){
cin>>m;
m-=2;
n=2;
res.m[0][0]=0;
res.m[1][0]=1;
res.m[1][1]=1;
res.m[0][1]=1;
if(m<0) cout<<1;
else {quickpower(m,n);
cout<<(ans.m[1][0]+ans.m[1][1])%mod;}
}