2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > 【C 语言】二级指针作为输入 ( 指针数组 | 指针数组排序 | 字符串排序 | strcmp 函数 )

【C 语言】二级指针作为输入 ( 指针数组 | 指针数组排序 | 字符串排序 | strcmp 函数 )

时间:2024-06-16 18:29:52

相关推荐

【C 语言】二级指针作为输入 ( 指针数组 | 指针数组排序 | 字符串排序 | strcmp 函数 )

文章目录

一、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;/** 复杂指针阅读* 参考 /shulianghan/article/details/121453520 和* https://hanshuliang./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;}

执行结果 :

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。