问题描述
- 程序运行异常 c语言小问题 求助
-
想写一个求大数的斐波那契的程序,需要数组来实现进位,然后进位条件那(就是for循环的条件那里)有问题 ,改一下(改成c!=0或改成a[i-1][j]!=0||a[i-2][j]!=0,合起来就不对了)就可以正常运行,想问下现在这样写有什么问题吗?#include
#includeconst int A=10000;
int a[1000][10];int main()
{
int n,i,j,c,cc;
memset(a,0,sizeof(a));
a[0][0]=a[1][0]=1;
for(i=2; i
{
c=0;
for(j=0; c!=0||a[i-1][j]!=0||a[i-2][j]!=0 ; j++)//进位条件
{
a[i][j]=(a[i-1][j]+a[i-2][j]+c)%A;
c=(a[i-1][j]+a[i-2][j]+c)/A;
}
}
while(~scanf("%d",&n))
{
for(i=0; a[n-1][i]!=0; i++) {}
i--;
cc=i;
for(; i>=0; i--)
if(i==cc)
printf("%d",a[n-1][i]);
else
printf("%05d",a[n-1][i]);
printf("n");
}
return 0;
}
解决方案
c!=0与a[i-1][j]!=0||a[i-2][j]!=0 不同时满足的话,你合在一起当然不会跳出循环啦,如果你要满足其一就可以结束for循环的话,那么可以判断条件:c!=0 && a[i-1][j]!=0&&a[i-2][j]!=0 ,表明的是当c==0、a[i-1][j]==0,a[i-2][j]==0同时满足的时候继续for循环,否则只要有一项不满足条件就跳出循环。