每日一个小算法。快速排序
来源:互联网 发布:手机壁纸软件may 编辑:程序博客网 时间:2024/05/21 22:41
快速排序就是特别版的冒泡排序。最差情况下时间复杂度为O(N*N),平均复杂度为O(N*logN)。基于二分思想。下面public class Sort {
输出结果:2 3 4 5 6 6 6 6 7 8 9 10 61
public class Sort {static int[] sortArray = new int[] {6,6,6,6,61,2,7,9,3,4,5,10,8 };static int n = sortArray.length;public static void main(String[] args) {sort(0, n-1);for (int i1 = 0; i1 < sortArray.length; i1++) {System.out.print(sortArray[i1] + " ");}}public static void sort(int left, int right) {int temp, i, j, t;if (left > right) {return;}temp = sortArray[left];i = left;j = right;while (i != j) {while (sortArray[j] >= temp && i < j)j--;while (sortArray[i] <= temp && i < j)i++;if (i < j) {t = sortArray[i];sortArray[i] = sortArray[j];sortArray[j] = t;}}sortArray[left] = sortArray[i];sortArray[i] = temp;sort(left, i - 1);sort(i + 1, right);}}
输出结果:2 3 4 5 6 6 6 6 7 8 9 10 61
0 0
- 每日一个小算法。快速排序
- 每日一个小算法-冒泡排序
- 【每日算法】快速排序
- 每日一个小算法(二)-插入排序
- 每日一个小算法-简化版桶排序
- 每日一算法--快速排序
- 每日算法1:快速排序
- 每日一算法之快速排序
- 【每日算法】快速排序及其应用
- 一个快速排序的算法
- 一个快速排序的算法
- 一个C快速排序算法
- 一个php快速排序算法
- 每日一算法之快速排序原理及实现
- 每日一算法之快速排序原理及实现
- 每天一个小算法 --- 排序
- 【每日算法】快速幂
- 一个快速排序的小技巧
- nyoj20-吝啬的国度
- sql---临时表
- Tomcat与Jre绿色环境配置(生产环境)【参考自用】
- prototype 原型链
- 如何避免应用崩溃
- 每日一个小算法。快速排序
- [转]JQuery更改input元素的disabled属性——disabled<——>enabled
- 学习编程是为了什么?
- 多个js文件合并为一个大js文件的方法
- 单源点最短路径Dijkstra和Bellmanford
- [HDU2196]Computer(树形dp)
- openoffice实现office文件转换为pdf实现文件预览
- Android之二维码的扫描与生成
- 快排的非递归实现