1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > 【C 语言】二级指针作为输入 ( 指针数组 | 将 二级指针 作为函数输入 | 抽象函数业务逻辑 )

【C 语言】二级指针作为输入 ( 指针数组 | 将 二级指针 作为函数输入 | 抽象函数业务逻辑 )

时间:2023-05-31 08:13:32

相关推荐

【C 语言】二级指针作为输入 ( 指针数组 | 将 二级指针 作为函数输入 | 抽象函数业务逻辑 )

文章目录

一、打印 指针数组 中指针指向的字符串二、字符串排序三、代码示例

一、打印 指针数组 中指针指向的字符串

打印 指针数组 中指针指向的字符串 :

指针退化问题 :传入二级指针 , 同时还要传入 一级指针的个数 ; 实参是 指针数组 , 形参 退化为 二级指针 , 需要人为指定 数组的元素个数 ;验证指针合法性 :函数中 , 只要是指针 , 就有可能为 NULL , 函数入口就要验证该指针合法性 ;

/** 打印函数*/int printf_array(char **array, int num){// 验证指针合法性if(array == NULL || num <= 0){printf("error : array == NULL || num <= 0\n");return -1;}// 循环控制变量int i = 0;// 打印上述数组for(i = 0; i < num; i++){// 使用 数组下标 与 指针 进行遍历 , 效果相同//printf("%s\n", array[i]);printf("%s\n", *(array + i));}return 0;}

二、字符串排序

将 指针数组 作为参数 , 传入函数中 ;

函数的 二级指针 形参 , 既要作为 输入 , 又要作为输出 ;

int sort_array(char **array, int num){// 验证指针合法性if(array == NULL || num <= 0){printf("error : array == NULL || num <= 0\n");return -1;}// 循环控制变量int i = 0, j = 0;// 排序时 , 交换指针变量时的临时变量char *tmp;// 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比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;}}}return 0;}

三、代码示例

完整代码示例 :

#include <stdio.h>#include <stdlib.h>#include <string.h>/** 打印函数*/int printf_array(char **array, int num){// 验证指针合法性if(array == NULL || num <= 0){printf("error : array == NULL || num <= 0\n");return -1;}// 循环控制变量int i = 0;// 打印上述数组for(i = 0; i < num; i++){// 使用 数组下标 与 指针 进行遍历 , 效果相同//printf("%s\n", array[i]);printf("%s\n", *(array + i));}return 0;}int sort_array(char **array, int num){// 验证指针合法性if(array == NULL || num <= 0){printf("error : array == NULL || num <= 0\n");return -1;}// 循环控制变量int i = 0, j = 0;// 排序时 , 交换指针变量时的临时变量char *tmp;// 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比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;}}}return 0;}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]);// 打印数组printf_array(array, num);// 对 指针数组 进行排序 , 排序依据是 指针 指向的数据对比sort_array(array, num);// 打印排序后的数组printf("\nSort:\n");printf_array(array, num);// 命令行不要退出system("pause");return;}

执行结果 :

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