转http://www.cyrec.org/posts/c-string-reverse
#include <stdio.h>
#include <string.h>#include <malloc.h>
int strReverse(char *to,char *from)
{
char *ptr;
to=(char*)malloc(strlen(from)+1);
ptr=to;
while(*from)
{
from++;
}
--from;//最后一位'\0'
while(*from)
{
*ptr=*from;
++ptr;
--from;
}
*ptr='\0';
printf("%s\n",to);
return 0;
}
void main()
{
char *from="hello world";
char *to;
strReverse(to,from);
}
#include <stdio.h>
#include <string.h>
char * Reverse (char *s)
{
if(strlen(s) == 1)
return s;
if(*(s))
{
int len = strlen(s);
*(s+len) = *s;
*s = *(s+len-1);
*(s+len-1) = '\0';
//首尾字符及结束符交换位置
Reverse (s+1); //去掉首尾字符后再递归调用
*(s+len-1) = *(s+len);
*(s+len) = '\0'; // 恢复原来改变后的串,这里也会递归的恢复
}
return s;
}
void main()
{
char from[] = "abcd";
printf("%s\n",Reverse(from));
}
这种递归的方法在网上看到的,C语言不熟悉,开始没看懂,后来查了下资料,strlen()函数和printf("%s",str)都是遇
到'\0'结束符终止的.还有递归方法在递归执行时候遇到不满足条件情况下还要递归退出嵌套层.还有就是一个
char *a和char a[]区别,网上解释是:char a[]={ 'a ', 'b ', 'c '}; 'a ', 'b ', 'c ' 在栈里,可以去改变它 ,
char *a = "abc "; "abc "在静态存储区,不可以改变。