C语言问题,求高手解答,谢谢!
函数fun用于将一字符串按相反次序显示,则横线上的表达式为().voidfun(char*s){if(!*s)return;_____;printf("%c",*s);}...
函数fun用于将一字符串按相反次序显示,则横线上的表达式为( ).
void fun(char *s)
{ if(! *s)
return;
_____;
printf("%c",*s);
}
A、printf("%s",s+1);
B、fun(*(s+1));
C、printf("%s",s+strlen(s)-1);
D、fun(s+1); 答案为D,不会呀,求高手解释,谢谢。 展开
void fun(char *s)
{ if(! *s)
return;
_____;
printf("%c",*s);
}
A、printf("%s",s+1);
B、fun(*(s+1));
C、printf("%s",s+strlen(s)-1);
D、fun(s+1); 答案为D,不会呀,求高手解释,谢谢。 展开
5个回答
展开全部
这是基本递归方法。
你做这题可以用排除法吧
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),这个时候就可以输出最后一个字符了。最好是上机跟踪调试一下。
你做这题可以用排除法吧
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了对吧,那么返回上一个,也就是字符串最后一个不为空的字符,并打印结束后再返回,
然后再逐个打印,就将字符串逆向打印出来了
{ if(! *s)
return;
fun(s+1);
printf("%c",*s);
}
不急,慢慢推,
运行第一次的时候,s为首地址的对吧,我们假设为s0,
在调用fun(s+1)时,进入一个递归,此时,还未调用到打印的地方,那么此时s为第二个字符,此时s为s1,
依次类推,当运行到最后一位是打印的数据为s(end),此时s(end)为空字符,return了对吧,那么返回上一个,也就是字符串最后一个不为空的字符,并打印结束后再返回,
然后再逐个打印,就将字符串逆向打印出来了
追问
高手能举个例子吗?我是菜鸟···
追答
汗
比方说这样吧,字符串为“abc”
我将整个的运行写出来
void fun(char *s)
{ if(! *s)
return;
// fun(s+1);
if(! *s)
return;
// fun(s+1);
if(! *s)
return;
// fun(s+1);
if(! *s)
return;//此时*s为'\0'
printf("%c",*s);//此时*s为c
printf("%c",*s);//此时*s为b
printf("%c",*s);//此时*s为a
}
再不懂,加好友说吧
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
使用递归的方法。
假设 s指针指向字符数组 helloword!
那么 s代表的是字符数组的首地址。printf("%c",*s);即输出 h
程序调用 fun(s+1); 进行递归。直到最后一个元素!
最后从后面进行逐个输出。即可达到相反次序显示
假设 s指针指向字符数组 helloword!
那么 s代表的是字符数组的首地址。printf("%c",*s);即输出 h
程序调用 fun(s+1); 进行递归。直到最后一个元素!
最后从后面进行逐个输出。即可达到相反次序显示
追问
请问高手
if (! *s)是什么意思
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
递归调用问题,答案是找到指针所指向的结束标志‘\0’,找到之后就return,具体我就没运行过,希望能帮到你,
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这是个递归调用的函数,每次fun(s+1),一直到遇到\0,函数递归调用结束,那If后的条件就成立了,这时从后向前一步一步执行递归函数,一直推到最开始。从而实现逆序输出
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询