C语言通用工具库之qsort()函数

一、qsort()函数

对于较大型的数组而言, “快速排序”方法是最有效的排序算法之一。他把数组不断分成更小的数组。首先把数组分成俩部分,一部分的值都小于另一部分的值,直到排好序。

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

第一个参数是指针,指向待排序数组的首元素。ANSI C允许把指向任何数据类型的指针强制转换成指向void指针。
第二个参数是待排序的数量。
第三个参数表示数组每个元素的大小。
第四个参数是指向函数的指针,这个指针被指向的比较函数用于确定排序的顺序。该函数应接受俩个参数:分别指向带比较两项的指针。如果第一项的值大于第二项,比较函数则返回正数;如果俩项相同,则返回0,如果第一项的值小于第二项,则返回负数。

#include <stdio.h>
#include <stdlib.h>

#define NUM 40

void fillarray(double ar [], int n);
void showarray(const double ar [], int n);
int mycomp(const void *p1, const void *p2);

int main()
{
	double vals[NUM];
	fillarray(vals, NUM);
	puts("随机数组:");
	showarray(vals, NUM);
	qsort(vals, NUM, sizeof(double), mycomp);
	puts("\n排序数组:");
	showarray(vals, NUM);

	return 0;
}

void fillarray(double ar [], int n)
{
	int index = 0;
	for(index = 0; index < n; index++)
	{
		ar[index] = (double) rand() / ((double) rand() + 0.1);
	}
}

void showarray(const double ar[], int n)
{
	int index = 0;
	for(index = 0; index < n; index++)
	{
		printf("%9.4f", ar[index]);
		if(index % 6 == 5)
		{
			putchar('\n');
		}
	}
	if(index % 6 != 1)
	{
		putchar('\n');
	}
}

/* 按从小到大的顺序排序 */
int mycomp(const void *p1, const void *p2)
{
	/* 要使用指向double的指针来访问这俩个值 */
	const double *a1 = (const double *)p1;
	const double *a2 = (const double *)p2;
	if(*a1 < *a2)
	{
		return -1;
	}
	else if(*a1 == *a2)
	{
		return 0;
	}
	else
	{
		return 1;
	}
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值