简单c语言问题,大家帮忙看看
#include<stdio.h>voidfun(){charc;if((c=getchar())!='\n')fun();putchar(c);}main(){fun(...
#include<stdio.h>
void fun()
{
char c;
if((c=getchar())!='\n')
fun();
putchar(c);
}
main()
{
fun();
getchar();
}
怎么总是看不懂
c语言刚学,逆序输出的
可以给我仔细解释下吗
怎么递归调用的,putchar不是输出一个字符吗? 展开
void fun()
{
char c;
if((c=getchar())!='\n')
fun();
putchar(c);
}
main()
{
fun();
getchar();
}
怎么总是看不懂
c语言刚学,逆序输出的
可以给我仔细解释下吗
怎么递归调用的,putchar不是输出一个字符吗? 展开
5个回答
展开全部
void fun()
{
char c;
if((c = getchar()) != '\n') //读一次键盘到C1, 如果不是回车,
fun(); //就再次读一次键盘到C2, 如果不是回车,
//就再次读一次键盘到C3, 如果不是回车,
//……
putchar(c); //是回车就显示……C3C2C1。
}
//---------------------
递归,不是什么好东西。
它的递归次数,编程时,难以掌握。
使用的时候,才会知道。
这样,就有可能超出堆栈空间,造成系统崩溃。
{
char c;
if((c = getchar()) != '\n') //读一次键盘到C1, 如果不是回车,
fun(); //就再次读一次键盘到C2, 如果不是回车,
//就再次读一次键盘到C3, 如果不是回车,
//……
putchar(c); //是回车就显示……C3C2C1。
}
//---------------------
递归,不是什么好东西。
它的递归次数,编程时,难以掌握。
使用的时候,才会知道。
这样,就有可能超出堆栈空间,造成系统崩溃。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
简单的递归调用,递归就像栈一样有着先入后出的特性。最先输入的被放到了栈底,而最后输入的被放到了栈顶,按照先入后出的原理,栈顶的先出栈(输出),所以输出为逆序。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
说不清楚的,只能说是没有到回车换行的时候回递归调用fun函数,是先进入fun函数,所以最内层的fun函数紧接着输出的一定是一层一层往下接受字符后最后面的那个。
建议你用编译器的单步执行看一下调用过程。
建议你用编译器的单步执行看一下调用过程。
追问
谢谢你啊
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这是用递归来实现的,后进栈先出。可以查查你看的c语言书,看不懂问我。其实我也是初学者。
追问
哎,这次绕里面看不懂了
加我q吧,1279448250一起交流啊,呵呵
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询