这是基本递归方法。
你做这题可以用排除法吧
A 这个printf每次会输出一串,肯定不行了
B fun函数传入参数其实是字串指针,fun(*(s+1))传入的是char类型,好歹也得char *的指针类型啊
C 和A一样 每次必定输出一个字串。我们应该每次输出一个字符。
那就D吧
关于D,fun(s+1)肯定传入了字符指针,fun里面最后那句是 printf("%c",*s); 递归传入s+1,则最后会变成fun(s+strlen(s)-1),这个时候就可以输出最后一个字符了。最好是上机跟踪调试一下。
void fun(char *s)
{ if(! *s)
return;
fun(s+1);
printf("%c",*s);
}
不急,慢慢推,
运行第一次的时候,s为首地址的对吧,我们假设为s0,
在调用fun(s+1)时,进入一个递归,此时,还未调用到打印的地方,那么此时s为第二个字符,此时s为s1,
依次类推,当运行到最后一位是打印的数据为s(end),此时s(end)为空字符,return了对吧,那么返回上一个,也就是字符串最后一个不为空的字符,并打印结束后再返回,
然后再逐个打印,就将字符串逆向打印出来了
使用递归的方法。
假设 s指针指向字符数组 helloword!
那么 s代表的是字符数组的首地址。printf("%c",*s);即输出 h
程序调用 fun(s+1); 进行递归。直到最后一个元素!
最后从后面进行逐个输出。即可达到相反次序显示
递归调用问题,答案是找到指针所指向的结束标志‘\0’,找到之后就return,具体我就没运行过,希望能帮到你,
这是个递归调用的函数,每次fun(s+1),一直到遇到\0,函数递归调用结束,那If后的条件就成立了,这时从后向前一步一步执行递归函数,一直推到最开始。从而实现逆序输出