杭电ACM 1005谁能告诉我我哪错了?!?

#include<iostream>usingnamespacestd;intmain(){inta,b,n;for(;cin>>a>>b>>n;){if(a==0&&b... #include<iostream>
using namespace std;
int main()
{
int a,b,n;
for(;cin>>a>>b>>n;)
{
if(a==0&&b==0&&n==0) break;
else if(n==1) cout<<1;
else if(n==2) cout<<1;
else
{
int f[100],x=0,y,i,e;
f[1]=1;
f[2]=1;
for(i=3;i<=n;i++)
{
f[i]=(a*f[i-1]+b*f[i-2])%7;
int j,z=0,m=-1;
for(j=i-1;j>2;j--)
{
z=j;
if(f[i]==f[j]&&f[i-1]==f[j-1]) m=j;break;
}
if(m==z) {x=i-2;break;}
else y=f[i];
}
if(x!=0)
{
e=f[((n-2)%x)+2];
cout<<e<<endl;
}
else cout<<y<<endl;
}
}
return 0;
}
展开
 我来答
porker2008
2011-11-10 · TA获得超过1.4万个赞
知道大有可为答主
回答量:7066
采纳率:62%
帮助的人:1.1亿
展开全部
#include<iostream>
using namespace std;
int main()
{
int a,b,n;
for(;cin>>a>>b>>n;)
{
if(a==0&&b==0&&n==0) break;
else if(n==1) cout<<1<<endl;
else if(n==2) cout<<1<<endl;
else
{
a%=7;
b%=7;
int f[100],x=0,y,i,e;
f[1]=1;
f[2]=1;
for(i=3;i<=n;i++)
{
f[i]=(a*f[i-1]+b*f[i-2])%7;
int j,z=0,m=-1;
for(j=i-1;j>2;j--)
{
z=j;
if(f[i]==f[j]&&f[i-1]==f[j-1])
{
m=j;
break;
}
}
if(m==z)
{
x=i-j;break;
}
else
y=f[i];
}
if(x!=0)
{
e=f[((n-i)%x)+i-x];
cout<<e<<endl;
}
else cout<<y<<endl;
}
}
return 0;
}
litfish04
2011-11-10 · TA获得超过317个赞
知道小有建树答主
回答量:356
采纳率:0%
帮助的人:237万
展开全部
sorry 无题无真相,看代码不知道该看啥
追问
杭电 acm第1005题
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式