自学内容网 自学内容网

qsort函数(任意类型排序)

void qsort(void base, size_t num, size_t size, int (*compar)(const void*p1, const void*p2))排序函数,可以排序各种类型的函数

四个参数:

void qsort(

void base,:base指向数组的第一个元素

size_t num,:base指向的数组元素的个数(待排序元素的个数)

size_t size,:base指向数组中元素的大小(单位是字节)(一个元素的大小)

int (*compar)(const void*p1, const void*p2):函数指针,指针指向的函数是用来比较数组中的两个元素的

)

应用qsort时,第四个参数int (*compar)(const void*p1, const void*p2),这个函数指针是由自己构建的。

int (*compar)(const void*p1, const void*p2),返回值是int 类型,返回值是一个整形,函数指针会根据返回值   >0   ==0   <0,三种情况进行排序,默认为升序(倒序互换p1 p2位置即可)

在这个函数指针中p1代表第一个元素,p2代表第二个元素,由于传参时传递的void*类型,而返回值是int 类型,故需要(int *)强制类型转换,再进行*解引用获取地址内容,即写成* ( int* )形式。


原文地址:https://blog.csdn.net/bkmoo/article/details/136356436

免责声明:本站文章内容转载自网络资源,如侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!