C语言递归函数,实现字符串逆序输出,代码如下,想不通运行过程和原理,求解释
#include<stdio.h>#include<math.h>voidreverse(){charc;if((c=getchar())!='\n')reverse()...
#include<stdio.h>
#include<math.h>
void reverse()
{
char c;
if ((c = getchar()) != '\n')
reverse();
if (c != '\n')
putchar(c);
}
main()
{
reverse();
system("pause");
return 0; 展开
#include<math.h>
void reverse()
{
char c;
if ((c = getchar()) != '\n')
reverse();
if (c != '\n')
putchar(c);
}
main()
{
reverse();
system("pause");
return 0; 展开
2个回答
2017-11-14
展开全部
#includevoidf(){charch;if((ch=getchar())!='\n')f();if(ch!='\n')printf("%c",ch);//这个输出语句是写在了递归调用之后,会被压栈,先压栈的后输出,所以可以实现逆序输出,如果把这个语句移动到f();就不会压栈了}voidmain(){f();pri
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询