标题:关于递归
只看楼主
googleknow
Rank: 1
等 级:新手上路
帖 子:64
专家分:0
注 册:2006-5-19
 问题点数:0 回复次数:6 
关于递归

各位大侠,下面的代码为什么给出的结果是10,9,8,7,6,5,4,3,2,1

main()
{
duigui(int n);
duigui(10);
}

void duigui(int n)
{
if (n < 10)
{
duigui(n + 1);
}
printf("%d",n);
}
我想知道具体的执行过程

搜索更多相关主题的帖子: 递归 
2006-12-06 21:52
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
得分:0 
duigui(10);调用错了吧.

倚天照海花无数,流水高山心自知。
2006-12-06 21:56
googleknow
Rank: 1
等 级:新手上路
帖 子:64
专家分:0
注 册:2006-5-19
得分:0 

哦,的确错了,应该是:
main()
{
duigui(int n);
duigui(1);
}

void duigui(int n)
{
if (n < 10)
{
duigui(n + 1);
}
printf("%d",n);
}

为什么结果是:10,9,8,7,6,5,4,3,2,1

2006-12-06 21:58
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
得分:0 
以下是引用googleknow在2006-12-6 21:52:58的发言:

各位大侠,下面的代码为什么给出的结果是10,9,8,7,6,5,4,3,2,1

main()
{
duigui(int n);
duigui(10);
}

void duigui(int n)
{
if (n < 10)
{
duigui(n + 1);
}
printf("%d",n);
}
我想知道具体的执行过程

必有一错,单看你给出的结果来看,是红色部分.应该改成

digui(1);


倚天照海花无数,流水高山心自知。
2006-12-06 21:59
C语言学习者
Rank: 4
等 级:贵宾
威 望:13
帖 子:1278
专家分:0
注 册:2006-9-26
得分:0 

#include<stdio.h>
int main()
{
void duigui(int n);
duigui(1);
return 0;
}

void duigui(int n)
{
if (n < 10)
{
duigui(n + 1);
}
printf("%d ",n);
}


谁有强殖装甲第二部,可以Q我460054868
2006-12-06 22:00
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
得分:0 
掌握一下递归的过程.
再写一遍:

f(1)
{
if()
{
f(2);
{
if()
{
f(3);
{
...
printf(3);
}
}
printf(2);
}
}
printf(1);
}

倚天照海花无数,流水高山心自知。
2006-12-06 22:20
googleknow
Rank: 1
等 级:新手上路
帖 子:64
专家分:0
注 册:2006-5-19
得分:0 
谢谢版主了。
2006-12-08 22:29



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-107727-1-1.html




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

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