c++&java之快速排序算法

Posted yunshouhu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c++&java之快速排序算法相关的知识,希望对你有一定的参考价值。

#include <iostream>
#include <time.h>
using namespace std;

//https://baike.baidu.com/item/%E5%BF%AB%E9%80%9F%E6%8E%92%E5%BA%8F%E7%AE%97%E6%B3%95
void Qsort(int arr[], int low, int high){
    if (high <= low) return;
    int i = low;
    int j = high + 1;
    int key = arr[low];
    while (true)
    {
        /*从左向右找比key大的值*/
        while (arr[++i] < key)
        {
            if (i == high){
                break;
            }
        }
        /*从右向左找比key小的值*/
        while (arr[--j] > key)
        {
            if (j == low){
                break;
            }
        }
        if (i >= j) break;
        /*交换i,j对应的值*/
        int temp = arr[i];
        arr[i] = arr[j];
        arr[j] = temp;
    }
    /*中枢值与j对应值交换*/
    int temp = arr[low];
    arr[low] = arr[j];
    arr[j] = temp;
    Qsort(arr, low, j - 1);
    Qsort(arr, j + 1, high);
}

void swap(int* a,int i,int j)
{
    int temp=a[i];
    a[j]=a[i];
    a[i]=temp;
}
//https://blog.csdn.net/earbao/article/details/50417644
void quick_sort002(int* a,int left,int right)
{
    if(left >= right)
        return ;
    int i=left;
    int j=right;
    int key=a[left];

    while(i<j)
    {
        while(i<j && key <=a[j])
        {
            j--;
        }
        a[i]=a[j];
        while(i<j && key >= a[i])
        {
            i++;
        }
        a[j]=a[i];
    }
    a[i]=key;
    quick_sort002(a,left,i-1);
    quick_sort002(a,i+1,right);

}

int parition(int *a, int low, int high) {
    int left=low;
    int right=high;
    int pivot=a[low];
    while(left < right)//基数
    {
        while(left <right && pivot <=a[right])//找到比基数小的元素
        {
            right--;
        }
        a[left]=a[right];
        while(left<right && pivot >= a[left])//找到比基数大的元素
        {
            left++;
        }
        a[right]=a[left];
    }
    a[left]=pivot;
    return left;
}
//https://blog.csdn.net/earbao/article/details/50417644
void quick_sort(int* a,int low,int high) {
    if (low >= high)
        return;
    int pivot=parition(a,low,high);
    quick_sort(a,low,pivot-1);
    quick_sort(a,pivot+1,high);

}


#define NUM 16
#define MAX 100

void printData(const int *a);

//c++&java之快速排序算法
int main()
{
    srand((unsigned)time(0));

    {
        int* a=new int[NUM];
        for (int i = 0; i < NUM; ++i) {
            a[i]=rand()% MAX;
        }
        printf("待排数列:\\n");
        printData(a);
        Qsort(a, 0, NUM - 1);
        printf("排序后数列:\\n");
        printData(a);
        delete[] a;
    }

    {
        int* a=new int[NUM];
        for (int i = 0; i < NUM; ++i) {
            a[i]=rand()% MAX;
        }
        printf("待排数列:\\n");
        printData(a);
        quick_sort002(a, 0, NUM - 1);
        printf("排序后数列:\\n");
        printData(a);
        delete[] a;
    }
    {
        int* a=new int[NUM];
        for (int i = 0; i < NUM; ++i) {
            a[i]=rand()% MAX;
        }
        printf("待排数列:\\n");
        printData(a);
        quick_sort(a, 0, NUM - 1);
        printf("排序后数列:\\n");
        printData(a);
        delete[] a;
    }
    return 0;
}

void printData(const int *a) {
    for(int i = 0; i < NUM; i++)
    {
        cout << a[i] << " ";
    }
    cout<<endl;
}

package com.yunshouhu.test_rsa;

import java.security.SecureRandom;
import java.util.Arrays;

public class test_quick_sort {

    //https://www.sohu.com/a/246785807_684445
    private static int partition(int[] arr, int startIndex, int endIndex) {
        // 取第一个位置的元素作为基准元素
        int pivot = arr[startIndex];
        int left = startIndex;
        int right = endIndex;

        int index = startIndex;
        //大循环在左右指针重合或者交错时结束
        while (right >= left) {

            while (right >= left) {
                //right指针从右向左进行比较
                if (arr[right] < pivot) {
                    arr[left] = arr[right];
                    index = right;
                    left++;
                    break;
                }
                right--;
            }

            while (right >= left) {
                //left指针从左向右进行比较
                if (arr[left] > pivot) {
                    arr[right] = arr[left];
                    index = left;
                    right--;
                    break;
                }
                left++;
            }
        }
        arr[index] = pivot;
        return index;
    }

    public static void quickSort(int[] arr, int left, int right) {
        if (left >= right) {
            return;
        }
        // 得到基准元素位置
        int pivotIndex = partition(arr, left, right);
        // 用分治法递归数列的两部分
        quickSort(arr, left, pivotIndex - 1);
        quickSort(arr, pivotIndex + 1, right);
    }

    //https://baike.baidu.com/item/%E5%BF%AB%E9%80%9F%E6%8E%92%E5%BA%8F%E7%AE%97%E6%B3%95
    public static int[] qsort(int arr[], int start, int end) {
        int pivot = arr[start];
        int i = start;
        int j = end;
        while (i < j) {
            while ((i < j) && arr[j] > pivot) {
                j--;
            }
            while ((i < j) && arr[i] < pivot) {
                i++;
            }
            if (arr[i] == arr[j] && (i < j)) {
                i++;
            } else {
                int temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
            }
        }
        if (i - 1 > start) {
            arr = qsort(arr, start, i - 1);
        }
        if (j + 1 < end) {
            arr = qsort(arr, j + 1, end);
        }
        return arr;
    }

    public static void main(String[] args) {
        {
            int arr[] = new int[]{12, 4, 7, 6, 5, 3, 2, 8, 1};
            quickSort(arr, 0, arr.length - 1);
            System.out.println(Arrays.toString(arr));
        }
        {
            int len=16;
            int arr[] = new int[len];
            byte[] data=new byte[len];
            SecureRandom sr=new SecureRandom();
            sr.nextBytes(data);
            for (int i=0;i<data.length;i++) {
                arr[i]=data[i];
            }        
            quickSort(arr, 0, arr.length - 1);
            System.out.println(Arrays.toString(arr));
        }
        {
            int arr[] = new int[]{12, 4, 7, 6, 5, 3, 2, 8, 1};
            qsort(arr, 0, arr.length - 1);
            System.out.println(Arrays.toString(arr));
        }
        {
            int arr[] = new int[]{3, 3, 3, 7, 9, 122344, 4656, 34, 34, 4656, 5, 6, 7, 8, 9, 343, 57765, 23, 12321};
            int len = arr.length - 1;
            arr = qsort(arr, 0, len);
            System.out.println(Arrays.toString(arr));
        }
    }

}

 

以上是关于c++&java之快速排序算法的主要内容,如果未能解决你的问题,请参考以下文章

算法图解之快速排序

排序算法之快速排序(Java)

排序算法之快速排序(Java)

《算法图解》之快速排序

重温基础算法内部排序之快速排序法

重温基础算法内部排序之快速排序法