题目:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。这里写自定义目录标题
使用两种函数
函数1:通过数组的方式来反转
函数2:通过getchar()和putchar()进行反转
函数二详解
递归 :先 递 再 归
键盘输入字符串后 abcde留在缓冲区 a 是第一个会被取走的(也就是先进先出)
1.递
- n=5 ,next=getchar()这是获得了 缓冲区中的第一个字符 即 ‘a’,还剩’bcde’进入
- n=4 ,next=getchar()这是获得了 缓冲区中的第一个字符 即 ‘b’,还剩’cde’进入
… - n=1 ,next=getchar()这是获得了 缓冲区中的第一个字符 即 ‘e’,缓冲区没东西了。
2.归 ,进入putchar,开始输出:
- n=1 putchar(next)==> ‘e’,这个时候 n=1全部结束,即返回
- n=2 putchar(next)==> ‘d’,这个时候 n=2全部结束,即返回
… - n=5 putchar(next)==> ‘a’,结束。
代码
//题目:利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。
#include<stdio.h>
#include<string.h>
#include<math.h>
//abcde --> edcba
int main(){
void fun1(char a[]);
void fun2(int n );
char a[5]={'a','b','c','d','e'};
printf("%s\n",a);
// fun1(a);//方法一
int n=5;
printf("请输入:");
fun2 (n);//方法二
return 0;
}
void fun1(char a[] ){//1.通过数组的方式来反转
if(strlen(a)==1)
printf("%c",a[0]);//数组名在函数中做形参是指的是第一个字符的地址
else {
fun1(a+1);
printf("%c",a[0]);
}
}
void fun2(int n ){//2.通过getchar和putchar反转
char next;
if(n==1)
{
next=getchar();
putchar(next);
}else{
next=getchar();
fun2(n-1);
putchar(next);
}
}