怎样倒序排列一个字符串是我们很多时候需要的。此文在于抛砖引玉。
首先,我们要给出一个长度够用的字符串指针(dest)。
然后,递减这个指针到0。在递减的过程中,dest累加而我们预设的字符串累减。这种方式是指针标准操作方式。
我使用了预设字符串指针地址+这个字符串长度变量这种方式(因为递减长度也是在递减)。
第二种方式,就是使用数组。
代码如下:
#include "stdafx.h" #include <string.h> #include <stdlib.h> int _tmain(int argc, _TCHAR* argv[]) { char *src = "hello,world"; int len = strlen(src); char *dest = NULL; dest = (char *)malloc(len + 1); // dest = (char *)malloc(len + 1); // standard: 要为'\0'分配一个空间 char *d = dest; // char *s = &src[len - 1]; // standard: 指向最后一个字符 /* One way */ while (len-- != 0) { *d++ = *(src + len); // one way //*d++ = *s--; // standard: } *d = 0; // standard: 尾部要加0 /* Two way */ /* int i = 0; while (len-- != 0) { dest[i] = src[len]; // two way i++; } */ printf("%s\n", dest); free(dest); // standard: 使用完,应当释放空间,以免造成内存汇泄露 return 0; }
本文代码在VS2005调试通过。