| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 337 人关注过本帖
标题:这个递推的程序哪里错了?
只看楼主 加入收藏
septemp
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2010-10-24
结帖率:50%
收藏
已结贴  问题点数:16 回复次数:5 
这个递推的程序哪里错了?
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
cnfarer
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:179
帖 子:3330
专家分:21157
注 册:2010-1-19
收藏
得分:8 
这个一定要注意栈的大小!(很容易耗尽)

★★★★★为人民服务★★★★★
2010-10-30 14:50
m21wo
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
威 望:4
帖 子:440
专家分:1905
注 册:2010-9-23
收藏
得分:8 
把递归改为非递归的算法!!!

If You Want Something, Go Get It, Period.
2010-10-30 16:30
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
m21wo
Rank: 10Rank: 10Rank: 10
等 级:青峰侠
威 望:4
帖 子:440
专家分:1905
注 册:2010-9-23
收藏
得分:0 
程序代码:
#include <stdio.h>
#define N 1000
int main()
{
    int a[N];
    int m,n;
    while(scanf("%d%d",&n,&m)&&(m||n))
    {
        if((n<1)||(n>10000)||(m>10000)||(m<2))
        {
            fflush(stdin);
            printf("error,please input again!\n");
            continue;
        }
        else if(n<=3)
        {
            printf("%d\n",n%m);
        }
        else
        {
            a[1]=1;
            a[2]=2;
            a[3]=3;
            int i;
            for( i=4;i<=n;i++)
                a[i]=a[i-1]+a[i-3];
            printf("%d\n",a[i-1]%m);
        }
    }
}



这样就可以算出n在1000的范围内

If You Want Something, Go Get It, Period.
2010-10-31 10:27
快速回复:这个递推的程序哪里错了?
数据加载中...
 
   



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

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