算法:高速排序

Posted cynchanpin

tags:

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

技术分享


高速排序算法原理:见上图描写叙述。

代码例如以下:

package com.huan;

import java.util.Arrays;
import java.util.Random;

public class QuickSort {
	public static void main(String[] args) {
		int[] data = new int[10];
		for (int i = 0; i < 10; i++){
			data[i] = new Random().nextInt(1000);
		}

		System.out.println(Arrays.toString(data));
		
		quicksort(data, 0, data.length - 1);
		
		System.out.println(Arrays.toString(data));
	}
	
	public static void quicksort(int[] data, int i, int j){
		if(i < j){
			int m = i, n = j;
			int k = data[i];
			while(i < j){
				while (i < j && data[j] > k){
					j--;
				}
				data[i] = data[j];
				
				while (i < j && data[i] < k){
					i++;
				}
				data[j] = data[i];
			}
			data[i] = k;
			quicksort(data, m, i-1);
			quicksort(data, i+1, n);
		}
	}
}



以上是关于算法:高速排序的主要内容,如果未能解决你的问题,请参考以下文章

算法:高速排序

算法学习之排序算法(高速排序)

高速排序算法C++实现

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

各种排序算法总结篇(高速/堆/希尔/归并)

算法导论 第7章 高速排序