| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3396 人关注过本帖
标题:Memory Limit Exceeded(递归栈溢出)怎么解决
只看楼主 加入收藏
o天道酬勤o
Rank: 1
等 级:新手上路
帖 子:106
专家分:0
注 册:2016-11-4
结帖率:94.44%
收藏
已结贴  问题点数:10 回复次数:7 
Memory Limit Exceeded(递归栈溢出)怎么解决
程序代码:
#include<stdio.h>
int main()
{
    int fun(int a,int b,int n);
    int a,b,n,N;
    while(scanf("%d%d%d",&a,&b,&n)!=EOF)
    {
        if(!(a==0&&b==0&&n==0))
        {
        N=fun(a,b,n);
        printf("%d\n",N);
        }
    }
    return 0;
} 
int fun(int a,int b,int n)
{
    int N;
    if(n>2)
    {
        N=(a*fun(a,b,n-1)+b*fun(a,b,n-2))%7;
        return N;
    }
    else
    return 1;
}


[此贴子已经被作者于2017-2-27 07:38编辑过]

2017-02-26 17:18
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:10 
一般是内存溢出。你这个可能是输入的数据过大,栈溢出了。
2017-02-26 19:22
o天道酬勤o
Rank: 1
等 级:新手上路
帖 子:106
专家分:0
注 册:2016-11-4
收藏
得分:0 
回复 2楼 xzlxzlxzl
那怎么解决呢
2017-02-26 21:27
o天道酬勤o
Rank: 1
等 级:新手上路
帖 子:106
专家分:0
注 册:2016-11-4
收藏
得分:0 
怎么样改写程序,可以避免栈溢出呢
2017-02-26 22:39
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:0 
首先得提出题目要求
2017-02-27 08:22
o天道酬勤o
Rank: 1
等 级:新手上路
帖 子:106
专家分:0
注 册:2016-11-4
收藏
得分:0 
回复 5楼 rjsp


Problem Description
A number sequence is defined as follows:

f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * f(n - 2)) mod 7.

Given A, B, and n, you are to calculate the value of f(n).
 

Input
The input consists of multiple test cases. Each test case contains 3 integers A, B and n on a single line (1 <= A, B <= 1000, 1 <= n <= 100,000,000). Three zeros signal the end of input and this test case is not to be processed.
 

Output
For each test case, print the value of f(n) on a single line.
 

Sample Input
1 1 3
1 2 10
0 0 0
 

Sample Output
2
5
2017-02-27 08:53
xzlxzlxzl
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:湖北
等 级:贵宾
威 望:125
帖 子:1091
专家分:5825
注 册:2014-5-3
收藏
得分:0 
弃用递归,改用循环就可。
2017-02-27 09:04
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:0 
首先不应该用递归,你这递归中有太多的重复计算
其次,f(n)跟f(n-1)和f(n-2)相关,且f(n-1)和f(n-2)都小于7,所以f(n)的序列是循环的,最多七七四十九节长

2017-02-27 09:12
快速回复:Memory Limit Exceeded(递归栈溢出)怎么解决
数据加载中...
 
   



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

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