The input consists of multiple test cases. Each test
case contains 3 integers A, B and n on a single line (1 <= A, B <= 1000, 1
<= n <= 100,000,000). Three zeros signal the end of input and this test
case is not to be processed.
For each test case, print the value of f(n) on a single
line.
2
5
除了f1 和f2以外,每个数字都由前两个数字决定,这个是公式确定的也就是说,如果对于数列f1 f2 ..fa fb .fc fd 存在fa=fc且fd=fb 那么后续的一定循环,对于任意的fn,由于是mod 7所以其取值只能是0 1 2 3 4 5 6这7种可能这样对于任意的连续两个数字,fa fb,可能的组合就是7*7=49种,而实际上,0,0序列是一个特殊的情况,除非A B都是7的倍数,那么所有序列都是0,不然是不会出现00的可能的.所以,如果提取一个长为50的任意子序列,可以提取出49个连续对,这49个中肯定会有至少一个重复,也就是循环周期了.当时没做出来,看的题解,重点是找出循环节
1 #include<stdio.h>
2 #include<math.h>
3 int f(int a,int b,int n)
4 {
5 if(n==2)
6 return 1;
7 if(n==1)
8 return 1;
9 return (a*f(a,b,n-1)+b*f(a,b,n-2))%7;
10 }
11 int main()
12 {
13 int a,b;
14 int n;
15 while(scanf("%d%d%d",&a,&b,&n)==3)
16 {
17 if(a==b&&b==n&&n==0)
18 break;
19 else
20 printf("%d\n",f(a,b,n%49));
21 }
22 }