f[i] 的值由 f[i-1] 和 f[i-2] 求出,而f[i]的值只取0~6,因此该数列是循环的,周期<=49。
奇怪的地方(暂时弄不懂,mark着):
RE代码
#include<stdio.h>
int main()
{
int f[55];
f[1]=1;f[2]=1;
int a,b,n,roll;
while(scanf("%d%d%d",&a,&b,&n),a+b+n)
{
for(int i=3;i<51;i++)
{
f[i]=(a*f[i-1]+b*f[i-2])%7;
if(f[i]==1&&f[i-1]==1)
{
roll=i-2;
break;
}
}
n%=roll;
if(n==0)
printf("%d\n",f[roll]);
else
printf("%d\n",f[n]);
}
return 0;
}
AC代码:
#include<stdio.h>
int main()
{
int f[55];
f[1]=1;f[2]=1;
int a,b,n,i;
while(scanf("%d%d%d",&a,&b,&n),a+b+n)
{
for(i=3;i<51;i++)
{
f[i]=(a*f[i-1]+b*f[i-2])%7;
if(f[i]==1&&f[i-1]==1)
{
break;
}
}
n%=i-2;
if(n==0)
printf("%d\n",f[i-2]);
else
printf("%d\n",f[n]);
}
return 0;
}