用C语言写 字符串逆序输出

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用C语言写 字符串逆序输出相关的知识,希望对你有一定的参考价值。

逆序输出有很多种,具体的实现方法取决于你题目的要求
1. 如果只是要求逆序输出,那么可以采用类似的方法:
void reverse(char *s)

if(*s=='\0')
return;
reverse(s+1);
printf("%c",*s);

这种方法在s很长的情况下会一直递归到底,不是很好。
2. 如果需要将字符串整个逆序在函数外面输出,那么可能希望采用返回字符串指针的方式;实现如下:
char * reverse( char* s )

static char *p = s+strlen(s)-1; //p是一个静态变量,指向当前递归层处理的字符串尾,而s指向字符串头
if(s < p)

  char c = *p; //交换头尾字符
  *p = *s;
 *s = c;
p--; //尾向前挪一个
reverse(s+1); //相当于头向后挪一个

return s;

3.1 当然,有的时候,并不需要reverse函数本身递归,而是可以借助一些辅助的递归函数,比如说:
void reversehelp(char * head, char * end)

if (head < end)

char c = *head;
*head = *end;
*end = c;
reversehelp(++head, --end);


然后在调用时像这样调用:
char * reverse(char * s)

char * end = s + strlen(s) - 1;
reversehelp(s, end);
return s;

3.2 类似的辅助函数还可以采用一个字符串指针和一个长度参数的方式,如下例:
void reversehelp( char* s, int n )

if ( n > 1 )

char c = s[n-1];
s[n-1] = s[0];
s[0] = c;
reversehelp( s+1, n-2 );


然后在调用时如下:
char *reverse(char *s)

reversehelp( s, strlen(s) );
return s;
参考技术A 这是利用递归调用实现用堆栈保存字符的,举例说明:
[scanf("%d\n",&a);]假设输入1
a不等于0,开始循环,[a--]a=0
[revers();]假设输入abc并回车,假设调用的函数叫revers1,内容与revers()一样
revers1():
[c=getchar()]c='a'
因为c!='\n'成立,执行[revers();]假设调用的函数叫revers2,注意revers1执行到此尚未结束
revers2():
[c=getchar()]c='1'
因为c!='\n'成立,执行[revers();]调用revers3,revers2执行到此等待执行revers3完后继续执行
revers3():
[c=getchar()]c='c'
因为c!='\n'成立,执行[revers();]调用revers4
revers4():
[c=getchar()]c='\n'
因为c!='\n'不成立,执行下句
因为不满足c!='\n'直接函数返回revers3
因为c='c'满足条件c
!=
'\n'&&c>='a'&&c<='z'执行[putchar(c);]输出c,然后返回revers2
因为c='1'不满足条件c
!=
'\n'&&c>='a'&&c<='z'直接返回revers1
因为c='a'满足条件c
!=
'\n'&&c>='a'&&c<='z'执行[putchar(c);]输出a,然后返回main
输出换行,执行[return
0;]
最后得到的输出为ca,这是将输入的字符串中小写字母进行逆序输出,其他字符则被滤除

以上是关于用C语言写 字符串逆序输出的主要内容,如果未能解决你的问题,请参考以下文章

C语言将字符串逆序输出问题(用函数)

c语言:将递归的方法将一个正整数逆序输出

如何用C语言将字符串逆序输出?

C语言怎么用函数把一个字符串逆序存放,比如说原字符串是abcd,怎么将他改为dcba?

C语言:输入一个字符串,然后逆序输出

给出一个5位数,按逆序输出它的各位数字。如:输入12345,输出54321.