C语言中qsort函数怎么用?

Python012

C语言中qsort函数怎么用?,第1张

qsort函数是编译器函数库自带的快速排序函数。

qsort 的函数原型是:

void qsort(void*base,size_t num,size_t width,int(__cdecl*compare)(const void*,const void*))

它的参数为: 1 待排序数组首地址

2 数组中待排序元素数量

3 各元素的占用空间大小

4 指向函数的指针,用于确定排序的顺序

它在使用的时候需要包含头文件:stdlib.h

实例:

#include<stdio.h>

#include<stdlib.h>

int comp(const void*a,const void*b)

{

return *(int*)a-*(int*)b

}

int main()

{

int *array

int n

scanf("%d",&n)

array=(int*)malloc(n*sizeof(int))

int i=0

for(i<ni++)

{

scanf("%d",(array+i))

}

qsort(array,n,sizeof(int),comp)

for(i=0i<ni++)

{

printf("%d\t",array[i])

}

return0

}

1、“快速排序法”使用的是递归原理,下面一个例子来说明“快速排序法”的原理。首先给出一个数组{53,12,98,63,18,72,80,46, 32,21},先找到第一个数--53,把它作为中间值,也就是说,要把53放在一个位置,使得它左边的值比它小,右边的值比它大。{21,12,32, 46,18,53,80,72,63,98},这样一个数组的排序就变成了两个小数组的排序--53左边的数组和53右边的数组,而这两个数组继续用同样的方式继续下去,一直到顺序完全正确。一般来说,冒泡法是程序员最先接触的排序方法,它的优点是原理简单,编程实现容易,但它的缺点就是速度太慢。

2、快速排序代码:

#include<stdio.h>

void quicksort(int a[],int left,int right)

{

    int i,j,temp

    i=left

    j=right

    temp=a[left]

    if(left>right)

        return

    while(i!=j)

    {

        while(a[j]>=temp&&j>i)

            j--

        if(j>i)

            a[i++]=a[j]

        while(a[i]<=temp&&j>i)

            i++

        if(j>i)

            a[j--]=a[i]

        

    }

    a[i]=temp

    quicksort(a,left,i-1)

    quicksort(a,i+1,right)

}

void main()

{

    int a[]={53,12,98,63,18,72,80,46,32,21}

    int i

    quicksort(a,0,9)

    /*排好序的结果*/

    for(i=0i<10i++)

        printf("%4d\n",a[i])

}