C语言 快速排序——qsort函数的介绍-2. 函数使用

时间:2024-04-17 07:29:59

注意:qsort 函数默认排升序!!
如果想排降序,把下面代码中的p1与p2互换即可!!

2.1 整型排序

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

//使用者自己定义的比较整型的函数
int cmp_int(const void* p1, const void* p2)
{
	//int* e1 = (int*)p1;
	//int* e2 = (int*)p2;
	//if (*e1 > *e1)
	//	return 1;
	//else if (*e1 == *e1)
	//	return 0;
	//else
	//	return -1;

	//上面的代码可简化为:
	return *(int*)p1 - *(int*)p2;
}

void print_int(int arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}
	printf("\n");
}

void test1()
{
	int arr[] = { 5,4,8,9,6,3,2,1 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), cmp_int);
	print_int(arr, sz);

}

int main()
{
	test1();

	return 0;
}

2.2 字符排序

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

int cmp_char(const void* p1, const void* p2)
{
	return *(char*)p1 - *(char*)p2;
}

void Print_char(char arr[], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%c ", arr[i]);
	}
	printf("\n");
}

void test2()
{
	char arr[] = { 'd','r','a','w'};
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), cmp_char);
	Print_char(arr, sz)
}

int main()
{
	test2();

	return 0;
}

2.3 字符串排序

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

int cmp_chars(const void* p1, const void* p2)
{
	return (*(char*)p1-*(char*)p2);
}

void print_char(char arr[][20], int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s\n", arr[i]);
	}
}

void test3()
{
	char arr[5][20] = { "hello world","apple","banana" };
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), cmp_char);
	print_chars(arr, sz);
}

int main()
{
	test3();

	return 0;
}

2.4 结构体排序

1.按名字排序

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

struct Stu
{
	char name[20];
	int age;
};

void print_struct(struct Stu* arr, int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d\n", arr[i].name, arr[i].age);
	}
}

int cmp_name(const void* p1, const void* p2)
{
     //比较两个字符串,用strcmp函数
	return strcmp(((struct Stu*)p1)->name, ((struct Stu*)p2)->name);
}

void test4()
{
	struct Stu arr[3] = { {"zhangsan",24},{"lisi",18},{"wangwu",49} };
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), cmp_name);
	print_struct(arr, sz);
}

int main()
{
	test4();
	
	return 0;
}
  1. 按年龄排序
#include <stdio.h>
#include <stdlib.h>

struct Stu
{
	char name[20];
	int age;
};

void print_struct(struct Stu* arr, int sz)
{
	int i = 0;
	for (i = 0; i < sz; i++)
	{
		printf("%s %d\n", arr[i].name, arr[i].age);
	}
}

int cmp_age(const void* p1, const void* p2)
{
	return ((struct Stu*)p1)->age - ((struct Stu*)p2)->age;
}

void test5()
{
	struct Stu arr[3] = { {"zhangsan",24},{"lisi",18},{"wangwu",49} };
	int sz = sizeof(arr) / sizeof(arr[0]);
	qsort(arr, sz, sizeof(arr[0]), cmp_age);
	print_struct(arr, sz);

int main()
{
	test5();
	
	return 0;
}