标签:
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 127502 Accepted Submission(s): 30987
//这份代码就没什么好解释了,找循环节 #include <stdio.h> int main () { int f[51]; int a, b, n,i,T; while(scanf("%d%d%d",&a,&b,&n),a||b||n) { f[1]=f[2]=1; for (i=3;i<50;i++) { f[i]=(a*f[i-1]+b*f[i-2])%7; if (f[i]==1&&f[i-1]==1) { break; } } T=i-2; f[0]=f[T]; printf ("%d\n", f[n%T]); } return 0; }
/*记得当时刚学,不会这种高级方法,大神在旁边看了一眼,直接给构造了一个矩阵,交了我幂取模,满满的崇拜和感谢
刚开始学,朋友不多,有人教一个东西,感觉真幸运,自学可能又要好久吧*/
#include<iostream> #include<cstdio> #include<cstring> using namespace std; struct matrix{ int Q[10][10]; }; matrix mult_pow(matrix a,matrix b){//矩阵乘法 int i,j,k; matrix c; memset(c.Q,0,sizeof(c.Q)); for(i=1;i<=2;i++) for(j=1;j<=2;j++) for(k=1;k<=2;k++) c.Q[i][j]=(c.Q[i][j]+a.Q[i][k]*b.Q[k][j])%7; return c; } matrix mult_pow_mod(matrix a,int n){ matrix ret;//构造矩阵 ret.Q[1][1]=1; ret.Q[1][2]=0; ret.Q[2][1]=0; ret.Q[2][2]=1; while(n){//快速密取模 if(n&1) ret=mult_pow(ret,a); a=mult_pow(a,a); n/=2; } return ret; } int main(){ int a,b,n; while(cin>>a>>b>>n){ if(a==0) break; if(n<=2) { printf("1\n"); continue; } matrix A;//构造矩阵 A.Q[1][1]=a; A.Q[1][2]=b; A.Q[2][1]=1; A.Q[2][2]=0; A=mult_pow_mod(A,n-2); printf("%d\n",(A.Q[1][1]+A.Q[1][2])%7); } return 0; }
标签:
原文地址:http://www.cnblogs.com/wabi87547568/p/4687843.html