文章目录
一、strcmp 函数
二、指针数组排序 ( 字符串排序 )
二、完整代码示例
一、strcmp 函数
strcmp 是 String Compare 缩写 , 该函数用于比较两个字符串 ;
strcmp 函数 :
#include <string.h> int __cdecl strcmp(const char *_Str1,const char *_Str2);
_Str1 < _Str2 : 返回负数 ;
_Str1 = _Str2 : 返回0 ;
_Str1 > _Str2 : 返回正数 ;
二、指针数组排序 ( 字符串排序 )
指针数组 中的每个元素都是 指向 字符串的指针 , 通过 strcmp 函数对字符串进行排序 , 代码如下 :
// 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比 for(i = 0; i < num; i++) { for(j = i; j < num; j++) { // 核心逻辑 : 如果 array[i] 大于 array[j] // 就交换两个元素 if(strcmp(array[i], array[j]) > 0) { // 交换 i, j 位置的指针变量 tmp = array[i]; array[i] = array[j]; array[j] = tmp; } } }
上述代码是将字符串有小到大进行排序 ;
二、完整代码示例
代码示例 :
#include <stdio.h> #include <stdlib.h> #include <string.h> void main() { // 循环控制变量 int i = 0, j = 0; // 数组大小 int num = 0; // 排序时 , 交换指针变量时的临时变量 char *tmp; /* * 复杂指针阅读 * 参考 https://blog.csdn.net/shulianghan/article/details/121453520 和 * https://hanshuliang.blog.csdn.net/article/details/78568351#3____________________2803 * 博客章节进行阅读 * * 复杂指针解析流程 : * 1. 中心标识符是 array * 2. 先往右看 , 遇到 [] , 说明这是一个数组 , 挖掉 array[] 内容 , 然后调转方向往左看 * 3. 发现是 * , 说明数组中的元素是指针 , 挖掉 * , 往右看没内容 , 往左看 * 4. 发现是 char , 说明指针指向的数据是 char 类型 * * array 是一个数组 , 数组中的元素的 char * 字符串 * * 这是 指针数组 , 数组元素 是 指针 */ char *array[] = {"abc", "123", "258", "sfd"}; // 计算数组大小 num = sizeof(array) / sizeof(array[0]); // 打印上述数组 for(i = 0; i < num; i++) { // 使用 数组下标 与 指针 进行遍历 , 效果相同 //printf("%s\n", array[i]); printf("%s\n", *(array + i)); } // 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比 for(i = 0; i < num; i++) { for(j = i; j < num; j++) { // 核心逻辑 : 如果 array[i] 大于 array[j] // 就交换两个元素 if(strcmp(array[i], array[j]) > 0) { // 交换 i, j 位置的指针变量 tmp = array[i]; array[i] = array[j]; array[j] = tmp; } } } // 打印排序后的数组 printf("\nSort:\n"); for(i = 0; i < num; i++) { // 使用 数组下标 与 指针 进行遍历 , 效果相同 printf("%s\n", array[i]); //printf("%s\n", *(array + i)); } // 命令行不要退出 system("pause"); return; }
执行结果 :