| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 337 人关注过本帖
标题:这个递推的程序哪里错了?
取消只看楼主 加入收藏
septemp
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-10-24
结帖率:50%
收藏
已结贴  问题点数:16 回复次数:2 
这个递推的程序哪里错了?
Function f(n) is recursively defined as:
    f(n) = f(n-1) + f(n-3), n > 3
    f(n) = n, n <= 3
Write a program to calculate f(n) modulo m.
n <= 10000, 2 <= m <= 10000.

#include<stdio.h>
long f(long n)
{   long p;
    if(n<3) p=n;
    else p=f(n-1)+f(n-3);
    return p;
}
int main()
{
    long n,m,a;
    while(scanf("%ld%ld",&n,&m)&&(n||m))
    {
        while((n<1)||(n>10000)||(m>10000)||(m<2))
        {
            scanf("%ld%ld",&n,&m);
        }
        a=f(n);
        printf("%ld\n",a%m);
    }
    return 0;
}
n>=50就卡住了
搜索更多相关主题的帖子: include return 
2010-10-30 13:35
septemp
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-10-24
收藏
得分:0 
怎么改啊
2010-10-31 07:52
septemp
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-10-24
收藏
得分:0 
#include <stdio.h>
int main()
{
    int n,m,a,b,c,d,i;
    while(scanf("%d%d",&n,&m)&&(m||n))
    {
        while((n<1)||(n>10000)||(m>10000)||(m<2))
            scanf("%d%d",&n,&m);
        if(n<=3) printf("%d\n",n%m);
        else
        {
            a=1;
            b=2;
            c=3;
            for(i=0; i<n-3; i++)
            {
                d=a+c;
                a=b;
                b=c;
                c=c+a;
            }
            printf("%d\n",d%m);
        }
    }
    return 0;
}

改了一下好像又错了

[ 本帖最后由 septemp 于 2010-10-31 08:41 编辑 ]
2010-10-31 08:35
快速回复:这个递推的程序哪里错了?
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.043429 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved