| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2020 人关注过本帖
标题:将字符用递归法逆序输出
只看楼主 加入收藏
宇智波曌
Rank: 2
等 级:论坛游民
帖 子:98
专家分:15
注 册:2011-4-17
结帖率:100%
收藏
已结贴  问题点数:2 回复次数:4 
将字符用递归法逆序输出
#include <stdio.h>
#include <string.h >
void fun(char str[])
{
    int i;
for (i=strlen(str)-1;i>=0;i--)
printf("%c", str[i]);
printf("\n");
}
void main()
{
char str[81];
printf("input the string :\n");
scanf("%s",str);
fun(str);
printf("%s\n",str);
}
这个程序能改成递归吗?
搜索更多相关主题的帖子: include 
2011-05-07 19:16
tisyang
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:132
专家分:737
注 册:2011-5-7
收藏
得分:0 
这也是个递归,fun是递归函数,但是fun 没有改变原字符串,只是逆序输出而已。
程序代码:
#include <stdio.h> 
void fun(char * p)
{
  if(*p != '\0')
    {
      fun(p+1);
      printf("%c", *p);
    }
}
int main()
{
  char str[81];
  printf("input the string :\n");
  scanf("%s",str);
  fun(str);
  printf("\n");
  printf("%s\n",str);
  return 0;
}

C++ 用无参数构造函数生成对象时候请勿在构造函数后添加无用的那一对括号,否则有可能会被当成函数声明而忽略,嗯,栈上构建的时候就是这样。
2011-05-07 20:08
宇智波曌
Rank: 2
等 级:论坛游民
帖 子:98
专家分:15
注 册:2011-4-17
收藏
得分:0 
回复 2楼 tisyang
你用的是指针啊!这个我还没学到啊
2011-05-07 21:10
tisyang
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:132
专家分:737
注 册:2011-5-7
收藏
得分:2 
回复 3楼 宇智波曌
这个用指针实现是很简洁的,当然也可以用数组的方法实现。
这个是数组方法,看起来没有用指针的自然。
程序代码:
#include <stdio.h>

 
void fun(char str[], int i)
{
  if(str[i] != '\0')
    {
      fun(str, i+1);
      printf("%c", str[i]);
    }
}
int main()
{
  char str[81];
  printf("input the string :\n");
  scanf("%s",str);
  fun(str, 0);
  printf("\n");
  printf("%s\n",str);
  return 0;
}

C++ 用无参数构造函数生成对象时候请勿在构造函数后添加无用的那一对括号,否则有可能会被当成函数声明而忽略,嗯,栈上构建的时候就是这样。
2011-05-07 21:23
宇智波曌
Rank: 2
等 级:论坛游民
帖 子:98
专家分:15
注 册:2011-4-17
收藏
得分:0 
回复 4楼 tisyang
谢啦!
2011-05-07 23:32
快速回复:将字符用递归法逆序输出
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.027576 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved