#include<stdio.h>
void reverse()
{
char ch;
if((ch=getchar())!='\n')
reverse();
if(ch!='\n')
putchar(ch);
return;
}
main()
{
reverse();
}
就这个函数,我看都没看懂呢!~
它怎么就把输入的字符串给逆置输出了呢?
哥/姐 帮忙下吧!~
书面说不明白 ,那语音吧!~
#include<stdio.h>
void reverse()
{
char ch;
if((ch=getchar())!='\n')
reverse();
if(ch!='\n')
putchar(ch);
return;
}
main()
{
reverse();
}
就这个函数,我看都没看懂呢!~
它怎么就把输入的字符串给逆置输出了呢?
哥/姐 帮忙下吧!~
书面说不明白 ,那语音吧!~
Reverse Reverse()
功能颠倒字符串中字符次序。
语法Reverse ( string )
参数string:要颠倒字符次序的字符串返回值String。函数执行成功时返回颠倒字符次序后的字符串,如果发生错误,那么返回空字符串("")。用法Reverse()函数将一个字符串中最后一个字符放置到另一个字符串的第一个字符位置、倒数第二个字符放置在另一个字符串的第二个字符位置,以此类推。
Reverse()系统中就有的;这里的的确不是调用系统的!
#include<stdio.h>
①void reverse()
{
char ch; //定义ch
if((ch=getchar())!='\n') //从键盘接受一个字符,如果不是换行符条件为真,执行②,否则执行③
②reverse(); //返回①递归接收字符
③if(ch!='\n') //判断ch是否为换行符,条件为真到④执行
④putchar(ch); //输出字符
return;
}
main()
{
reverse();
}
这个函数是用户自己定义的,不是系统函数。
为什么这样说,你可以看头文件,上面只有一个负责输入输出的头文件,并没有#include <string.h>
程序使用了“递归”算法,通过getchar()函数将输入的字符依次入栈,输入结束后,使用putchar(ch)函数,将字符从栈顶依次取出,这样输出就逆置了。这是使用了栈的特点:先进后出。
如:xiao,依次进栈:
o(栈顶)
a
i
x(栈底)
出栈是从栈顶开始取的,每取一次就输出。所以就逆置了:
oaix