用快速排序进行排序。

生成10000个随机数并用快速排序进行排序,c语言实现

你题目的解答代码如下:

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

#define N 10000


//函数swap交换两个数   c++里函数库有这个函数 可以直接写
void swap(int *a, int *b)
{
    int temp;
    temp = *a;
    *a = *b;
    *b = temp;
}
/*quicksort 快速排序算法
对数组arr[low...high]进行快速排序,
首先进行分割操作,返回中轴元素下标 j,
然后对左数组arr[low...j-1] 和 右数组arr[j+1...high]分别递归进行排序
递归终止当然是数组大小为小于等于1(0或1)时*/
void quicksort(int array[], int max, int low, int high)
{
    int i, j;

    if(low < high)
    {
        //int v = array[low];     //中轴元素v
        i = low + 1;            // array[low]作为基准数(一般第一个),从array[begin+1]开始与基准数比较
        j = high;               // array[high]是数组的最后一位
        while(i < j)
        {
            if(array[i] > array[low])  // 如果比较的数组元素大于基准数,则交换位置。
            {
                swap(&array[i], &array[j]);  // 交换两个数
                j--;
            }
            else
            {
                i++;                    // 将数组向后移一位,继续与基准数比较。
            }
        }

/* 跳出while循环后,i = j。
 * 然后就是分割操作了
 * 这个时候将数组array分成两个部分,再将array[i]与array[low]进行比较,决定array[i]的位置。
 * 最后将array[i]与array[high]交换,进行两个分割部分的排序!退出条件不满足i = j
 */

        if(array[i] >= array[low])  // 取等>=
        {
            i--;
        }

        swap(&array[low], &array[i]);

        quicksort(array, max, low, i);
        quicksort(array, max, j, high);
    }
}

// 主函数
int main()
{
    int a[N];
    srand((unsigned)time(NULL));
    for(int i=0;i<N;i++)
        a[i] = rand() % 10000;
    quicksort(a, N, 0, N-1);  // 快速排序

    printf("快速排序之后:");
    for(int j=0;j<N;j++)
        printf("%d ",a[j]);
    return 0;
}

如有帮助,望采纳!谢谢!