#include<iostream>
#include<cstring>
using namespace std;
const int N = 3;
int n,m;
void mul(int c[],int a[],int b[][N]){
int tmp[N] = {0};
for(int i=0;i<N;i++){
for(int j=0;j<N;j++){
tmp[i] = (tmp[i]+(long long)a[j]*b[j][i]) % m;
}
}
memcpy(c,tmp,sizeof tmp);
}
void mul(int c[][N],int a[][N],int b[][N]){
int tmp[N][N] = {0};
for(int i=0;i<N;i++){
for(int j=0;j<N;j++){
for(int k=0;k<N;k++)
tmp[i][j] = (tmp[i][j] + (long long)a[i][k]*b[k][j]) % m;
}
}
memcpy(c,tmp,sizeof tmp);
}
int main(){
scanf("%d%d",&n,&m);
int f1[N] = {1,1,1};
int a[N][N] = {
{0,1,0},
{1,1,1},
{0,0,1}
};
n--;
while(n){
if(n&1) mul(f1,f1,a);
mul(a,a,a);
n >>= 1;
}
printf("%d",f1[2]);
}
06-26
“相关推荐”对你有帮助么?
-
非常没帮助
-
没帮助
-
一般
-
有帮助
-
非常有帮助
提交