库函数qsort

 一、qsort的定义

二、使用qsort排序

1.int类型数据

//测试标准库函数qsort
//void qsort(void* base, size_t num, size_t size, int (*compar)(const void*, const void*))
#include<stdlib.h>

void print_int(int arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
	printf("\n");
}
int cmp_int(const void* p1, const void* p2)
{
	return *(int*)p1 - *(int*)p2;
}
void Test1()
{
	int arr[10] = { 2,6,7,4,5,1,3,9,0,8 };
	int sz = sizeof(arr) / sizeof(arr[0]);

	print_int(arr, sz);
	qsort(arr, sz, sizeof(arr[0]), cmp_int);
	print_int(arr, sz);
}
int main()
{
	Test1();
	//Test2();
	//Test3();

	return 0;
}

2.结构体类型数据

2.1按年龄排序

//测试标准库函数qsort
//void qsort(void* base, size_t num, size_t size, int (*compar)(const void*, const void*))
#include<stdlib.h>

struct stu
{
	char name[20];
	int age;
};
void print_stu(struct stu arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d     ", arr[i].name, arr[i].age);
	}
	printf("\n");
}
int cmp_stu_by_age(const void* p1, const void* p2)
{
	return ((struct stu*)p1)->age - ((struct stu*)p2)->age;
}
void Test2()
{
	struct stu arr[3] = { {"zhangsan",20},{"lisi",13},{"wangwu",16} };
	int sz = sizeof(arr) / sizeof(arr[0]);

	print_stu(arr, sz);
	qsort(arr, sz, sizeof(arr[0]), cmp_stu_by_age);
	print_stu(arr, sz);
}
int main()
{
	//Test1();
	Test2();
	//Test3();

	return 0;
}

2.2按姓名排序

//测试标准库函数qsort
//void qsort(void* base, size_t num, size_t size, int (*compar)(const void*, const void*))
#include<stdlib.h>
#include<string.h>

struct stu
{
	char name[20];
	int age;
};
void print_stu(struct stu arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d     ", arr[i].name, arr[i].age);
	}
	printf("\n");
}
int cmp_stu_by_name(const void* p1, const void* p2)
{
	//return strcmp(((struct stu*)p1)->name, ((struct stu*)p1)->name); //err
	return strcmp(((struct stu*)p1)->name, ((struct stu*)p2)->name);
}
void Test3()
{
	struct stu arr[3] = { {"zhangsan",20},{"lisi",13},{"wangwu",16} };
	int sz = sizeof(arr) / sizeof(arr[0]);

	print_stu(arr, sz);
	qsort(arr, sz, sizeof(arr[0]), cmp_stu_by_name);
	print_stu(arr, sz);
}
int main()
{
	//Test1();
	//Test2();
	Test3();

	return 0;
}

 利用库函数qsort的结构改造的适用于所有数据类型的冒泡排序BubbleSort: 冒泡排序BubbleSort_蒲公英不会飞的博客-CSDN博客

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值