快速排序 (QuickSort) Java数据结构与算法
2010-07-18 21:35
246 查看
快速排序 (QuickSort) Java数据结构与算法
源代码:
源代码:
/** * * @author sunnyykn */ class ArrayIns { private long[] theArray; private int nElems; public ArrayIns(int max) { theArray = new long[max]; nElems = 0; } public void insert(long value) { theArray[nElems] = value; nElems ++; } public void display() { System.out.print("A = "); for(int j = 0;j < nElems;j ++) System.out.print(theArray[j] + " "); System.out.println(""); } public void quickSort() { recQuickSort(0,nElems - 1); } public void recQuickSort(int left,int right) { if(right - left <= 0) return ; else{ long pivot = theArray[right]; int partition = partitionIt(left,right,pivot); recQuickSort(left,partition - 1); recQuickSort(partition + 1,right); } } public int partitionIt(int left,int right,long pivot) { int leftPtr = left - 1; int rightPtr = right; while(true) { while( theArray[++ leftPtr] < pivot ); while( rightPtr > 0 && theArray[-- rightPtr] > pivot ); if(leftPtr >= rightPtr) break; else swap(leftPtr,rightPtr); } swap(leftPtr,right); return leftPtr; } public void swap(int dex1,int dex2) { long temp = theArray[dex1]; theArray[dex1] = theArray[dex2]; theArray[dex2] = temp; } } class QuickSortApp { public static void main(String[] args) { int maxSize = 16; ArrayIns arr; arr = new ArrayIns(maxSize); for(int j = 0;j < maxSize;j ++) { long n = (int)(java.lang.Math.random()*99); arr.insert(n); } arr.display(); arr.quickSort(); arr.display(); } }
相关文章推荐
- quicksort 快速排序 java
- 快速排序quicksort-算法导论java实现
- 快速排序Quicksort Array in Java
- Java DualPivotQuickSort 双轴快速排序 源码 笔记
- 数据结构与算法(7)---Java语言实现:快速排序
- 快速排序 QuickSort Java代码
- QuickSort快速排序-Java
- Java数据结构与算法:快速排序
- java数据结构与算法-高级排序-快速排序
- Java 快速排序 quicksort
- 数据结构与算法总结——排序(二)归并排序,快速排序 和 堆排序
- 快速排序详解 Java实现
- [Java]快速排序,以及双基快排
- 快速排序,一个爱情故事-java版
- Java排序算法(七):快速排序
- java数组排序示例(冒泡排序、快速排序、希尔排序、选择排序)
- 算法-快速排序-java实现
- java 快速排序
- 快速排序 QuickSort
- 算法导论的Java实现----7. 快速排序