本题要求逆序输出一个字符串,要求用递归方式完成。
#include <stdio.h>
void reverse_str(char *p);
int main()
{
char str[80];
gets(str);
reverse_str(str);
return 0;
}
void reverse_str(char *p)
{
if(*p)
{
reverse_str(p + 1);
;
putchar(*p);
}
}
在这段程序中,定义了一个reverse_str
函数用来递归地逆序输出字符串。函数的参数是一个指针p
,指向字符串的首字符。
递归的结束条件是当指针p
所指的字符为\0
时,即字符串的结束符。在递归的过程中,每次递归调用reverse_str
函数时,将指针向后移动一个位置,即p+1
,逐渐递归到字符串的最后一个字符。
递归调用结束后,会执行putchar(*p)
语句,将当前字符输出到屏幕。由于是逆序输出,所以先输出的是字符串的最后一个字符,然后依次输出前面的字符,直到第一个字符。
需要注意的是,gets
函数在C11标准中已经被弃用,因为它存在安全漏洞。建议使用更安全的替代函数fgets
来读取字符串。