C语言用数组做递归的问题。

#include<stdio.h>#include<stdlib.h>intmain(){intn,m,r,j;intf[10000]={0,1,2,3};while(1... #include <stdio.h>
#include <stdlib.h>

int main()
{
int n,m,r,j;
int f[10000]= {0,1,2,3};
while(1)
{

printf("Please Input N and M:");
scanf("%d%d",&n,&m);
if(n==0&&m==0)
exit(0);
while(m<2||n>10000||m>10000)
{
printf("Please Input Conrect Numbers:");
scanf("%d%d",&n,&m);
}

for(j=4; j<=n; j++)
{
f[j]=f[j-1]%m+f[j-3]%m;
}

r = f[n]%m;
printf("%d\n",r);

}
return 0;
}
求大神指出错误。。
展开
 我来答
丷爫魚
2012-01-21 · 超过11用户采纳过TA的回答
知道答主
回答量:17
采纳率:0%
帮助的人:32.1万
展开全部
楼主,你这段代码除了漏洞,别的没有错误啊,你的目的是什么?
更多追问追答
追问
其实本质就是希望成功得到f[n]的值。小于一万的所有n都可行。但现在n=10000的时候就不好使。
追答
你声明的数组就只到了n=9999啊
int f[10000]是从f[0]到f[9999],f[10000]当然是未初始化的数啦
小懶蟲ing
2012-01-21 · TA获得超过144个赞
知道答主
回答量:113
采纳率:0%
帮助的人:101万
展开全部
程序语法没错啊,你是想问结果错了啊,你程序要实现的作用是什么?
追问
你们在      
for(j=4; j<=n; j++)
{
f[j]=f[j-1]%m+f[j-3]%m;
}
这个循环里面printf一下m。然后10000和999,最后发现最后一次循环m的值竟然变了,这是为什么?
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式