C/C++教程

C笔记 - 算法:字符串倒序

本文主要是介绍C笔记 - 算法:字符串倒序,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!

字符串倒序

1 - 代码示例:方式一(开辟新空间)

 1     char *stringDemo = "hollow,C++";
 2     int len = strlen(stringDemo);// 字符串长度 10
 3     
 4     // 开辟新的空间
 5     char *test = (char*)malloc(len+1);// 务必牢记要多分配一个空间
 6     char *d = test;
 7     char *s = &stringDemo[len -1];// 指向最后一个字符
 8     
 9     // 遍历赋值
10     while (len-- != 0) {
11         *d++ = *s--;
12     }
13     // 末尾
14     *d = 0;// 尾部要添加 '\0'
15     
16     printf("%s\n",test);// 输出 ++C,wolloh
17     free(test);// 是用完后记得释放
18     test = NULL;// 防止野指针

2 - 代码示例:方式二

 1     char string[] = "hollow,C++";
 2     int len = strlen(string);
 3     
 4     char temp;
 5     
 6     // 通过将 string 数组的第 1 个字符和第 n 个字符交换位置
 7     // 第2个和第 n-1 个交换,以此类推
 8     for (int i = 0; i < len/2; i++) {
 9         temp = string[i];
10         string[i] = string[len-i -1];
11         string[len-i-1] = temp;
12     }
13 
14     printf("%s\n",string);// 输出 ++C,wolloh

 

这篇关于C笔记 - 算法:字符串倒序的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!