Java排序七:快排
2016-03-01 23:35
330 查看
public class TestDemo { public static void main(String[] args) { int[] arr = new int[10]; Random random = new Random(); for (int i = 0; i < arr.length; i++) { arr[i] = random.nextInt(100); } display(arr); sort(arr, 0, arr.length - 1); display(arr); } public static void sort(int[] arr, int left, int right) { if (left < right) { int partition = getPartition(arr, left, right); sort(arr, left, partition - 1); sort(arr, partition + 1, right); } } private static int getPartition(int[] arr, int left, int right) { int temp = arr[left]; while (left < right) { while (arr[right] >= temp && left < right) { right--; } if (left < right) { arr[left++] = arr[right]; } while (arr[left] <= temp && left < right) { left++; } if (left < right) { arr[right--] = arr[left]; } } arr[left] = temp; return left; } private static void swap(int[] arr, int i, int j) { if (i == j) { return; } arr[i] = arr[i] ^ arr[j]; arr[j] = arr[i] ^ arr[j]; arr[i] = arr[i] ^ arr[j]; } private static void display(int[] arr) { for (int i = 0, len = arr.length; i < len; i++) { System.out.print(arr[i] + " "); } System.out.println(); } }
相关文章推荐
- 记录几个和时间有关的方法
- Java HashMap循环遍历方式及其性能对比
- Java排序五:归并排序
- 整合之道--Spring4整合Ehcache2.10
- try catch 的 return
- Java排序四:二分插入排序
- TIC TAC TOE 消去版
- Java排序三:直接插入排序
- Java排序二:选择排序
- Java排序一:冒泡排序
- Java排序六:堆排序
- java菜鸟须知
- springMVC-错误消息的显示和国际化
- JAXP简介
- Java初学者必看2
- java中ArrayList 、LinkList区别
- Java中IO流的介绍
- 【JAVA】2、搭建开发环境
- 公平锁 非公平锁
- [Java] 实验1