- 使用 Java 的 DSA 教程
- 使用 Java 的 DSA - 主页
- 使用 Java 的 DSA - 概述
- 使用 Java 的 DSA - 环境设置
- 使用 Java 的 DSA - 算法
- 使用 Java 的 DSA - 数据结构
- 使用 Java 的 DSA - 数组
- 使用 Java 的 DSA - 链表
- 使用 Java 的 DSA - 双向链表
- 使用 Java 的 DSA - 循环链表
- 使用 Java 的 DSA - 栈
- DSA - 解析表达式
- 使用 Java 的 DSA - 队列
- 使用 Java 的 DSA - 优先队列
- 使用 Java 的 DSA - 树
- 使用 Java 的 DSA - 哈希表
- 使用 Java 的 DSA - 堆
- 使用 Java 的 DSA - 图
- 使用 Java 的 DSA - 搜索技术
- 使用 Java 的 DSA - 排序技术
- 使用 Java 的 DSA - 递归
- 使用 Java 的 DSA 有用资源
- 使用 Java 的 DSA - 快速指南
- 使用 Java 的 DSA - 有用资源
- 使用 Java 的 DSA - 讨论
使用 Java 的 DSA - 快速排序
概述
快速排序是一种高效率的排序算法,基于将数据数组划分为较小的数组。一个大数组划分为两个数组,其中一个数组包含小于指定值(即根据它进行划分的枢纽)的值,另一个数组包含大于枢纽值的值。
快速排序对一个数组进行分割,然后递归调用自身两次来对生成的两个子数组进行排序。此算法对于大型数据集非常高效,因为它的平均和最差情况复杂度都是 O(nlogn),其中 n 是项数。
伪代码
A : array of items procedure quickSort(left, right) if right-left <= 0 return else pivot = A[right] partition = partitionFunc(left, right, pivot) quickSort(left,partition-1) quickSort(partition+1,right) end if end procedure function partitionFunc(left, right, pivot) leftPointer = left -1 rightPointer = right while True do while A[++leftPointer] < pivot do //donothing end while while rightPointer > 0 && A[--rightPointer] > pivot do //donothing end while if leftPointer >= rightPointer break else swap leftPointer,rightPointer end if end while swap leftPointer,right return leftPointer end function procedure swap (num1, num2) temp = A[num1] A[num1] = A[num2] A[num2] = temp; end procedure
演示程序
package com.tutorialspoint.advancedsort; import java.util.Arrays; public class QuickSortDemo { private static int[] intArray = {4,6,3,2,1,9,7}; public static void main(String[] args){ QuickSortDemo quickSortDemo = new QuickSortDemo(); System.out.println("Input Array: " +Arrays.toString(intArray)); printline(50); quickSortDemo.quickSort(0, intArray.length-1); System.out.println("Output Array: " + Arrays.toString(intArray)); printline(50); } public static void printline(int count){ for(int i=0;i <count-1;i++){ System.out.print("="); } System.out.println("="); } private int partition(int left, int right, int pivot){ int leftPointer = left -1; int rightPointer = right; while(true){ while(intArray[++leftPointer] < pivot){ //do nothing } while(rightPointer > 0 && intArray[--rightPointer] > pivot){ //do nothing } if(leftPointer >= rightPointer){ break; }else{ System.out.println(" item swapped :" + intArray[leftPointer]+","+intArray[rightPointer]); swap(leftPointer,rightPointer); } } System.out.println(" pivot swapped :" + intArray[leftPointer]+","+intArray[right]); swap(leftPointer,right); System.out.println("Updated Array: " + Arrays.toString(intArray)); return leftPointer; } private void swap(int num1, int num2){ int temp = intArray[num1]; intArray[num1] = intArray[num2]; intArray[num2] = temp; } public void quickSort(int left, int right){ if(right-left <= 0){ return; }else{ int pivot = intArray[right]; int partition = partition(left, right, pivot); quickSort(left,partition-1); quickSort(partition+1,right); } } }
如果我们编译并运行以上程序,它会生成以下结果 -
Input Array: [4, 6, 3, 2, 1, 9, 7] ================================================== pivot swapped :9,7 Updated Array: [4, 6, 3, 2, 1, 7, 9] pivot swapped :4,1 Updated Array: [1, 6, 3, 2, 4, 7, 9] item swapped :6,2 pivot swapped :6,4 Updated Array: [1, 2, 3, 4, 6, 7, 9] pivot swapped :3,3 Updated Array: [1, 2, 3, 4, 6, 7, 9] Output Array: [1, 2, 3, 4, 6, 7, 9] ==================================================
广告