C语言题目 - 调用qsort函数对数组进行排序

题目

如题

思路

其实没什么难的,只要严格按照 qsort 函数的参数来填充即可,这里要用到函数指针

qsort 函数的原型如下:

void qsort(void *base, size_t nitems, size_t size,
int (*compar)(const void *, const void *));

参数说明:

base :指向需要排序的数组的指针,数组中每个元素的大小应为 size 字节。
nitems :数组中的元素个数。
size :每个元素的大小(以字节为单位)。
compar:指向一个比较函数的指针。该函数用于比较两个元素的大小关系。

代码

c 复制代码
#include<stdio.h>
#include<stdlib.h>

//比较函数,也是qsort函数需要的指针参数指向的函数
int compare(const void * a, const void * b);

int main()
{
	int sz[5] = {1,5,2,6,4};//待排序的数组
    int (*compar)(const void *, const void *);//函数指针compar
	int * ps = sz;//指针指向sz数组
	int i;

	compar = compare;//指针指向compare函数

	qsort(ps, 5, 4, compar);//调用 qsort 函数

	for (i=0;i<5;i++)
	{
		printf("%d ",sz[i]);
	}//打印排序结果

	return 0;
}

int compare(const void * a, const void * b)
{
	int num1 = *(const int *)a;//void转换类型后才能使用
	int num2 = *(const int *)b;

	if (num1 > num2)
	{
		return 1;
	}

	if (num1 < num2)
	{
		return -1;
	}

	if (num1 == num2)
	{
		return 0;
	}
}

感悟

  • 要注意调用一个函数一定要严格按照它参数的函数类型来填充参数,比如说这里 qsort 函数的一个参数是 int (*compar)(const void *, const void *) ,那么这个参数是函数指针,函数指针的类型 int ,以及它的参数类型是 const void * ,这两个类型是一点都不能变的。但是在填充函数指针这个参数的时候可以选择填充 函数指针名函数名 ,因为当函数指针指向一个函数以后,这个函数指针名函数名 就可以互换使用了(只是用法差不多)。
  • 详细理解了 void * 类型的变量怎么使用:比如这里想把把它作为一个比较函数的参数使用,而且我想的是这两个数是 int 类型的,但有一点是 void * 类型的变量不转换类型是无法使用的,所以我要把 void * 类型的变量转换为 int 类型的变量:int num = *(const void *) a;
  • 首先,这个程序最后写的 compare 函数参数的意义是指向数组元素的指针,然后这个函数可以进行简化,让程序来判断元素大小:
c 复制代码
int compare(const void * a, const void * b)
{
	return (*(const int *)a - *(const int *)b);
}
相关推荐
cynicme2 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员2 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称2 小时前
【递归】二进制字符串中的第K位
c++·算法
mjhcsp3 小时前
C++ 循环结构:控制程序重复执行的核心机制
开发语言·c++·算法
立志成为大牛的小牛3 小时前
数据结构——四十一、分块查找(索引顺序查找)(王道408)
数据结构·学习·程序人生·考研·算法
xier_ran3 小时前
深度学习:RMSprop 优化算法详解
人工智能·深度学习·算法
地平线开发者4 小时前
不同传感器前中后融合方案简介
算法·自动驾驶
地平线开发者4 小时前
征程 6X 常见 kernel panic 问题
算法·自动驾驶
com_4sapi5 小时前
2025 权威认证头部矩阵系统全景对比发布 双榜单交叉验证
大数据·c语言·人工智能·算法·矩阵·机器人
前端小L5 小时前
二分查找专题(九):“降维”的魔术!将二维矩阵“拉平”为一维
数据结构·算法