- 快速排序
每次排序选取一个中间值,小的放到左边,大的放到右边;
public static void main(String[] args) {
// TODO Auto-generated method stub
int arry[] = {7,5,4,2,19,10,8,84,4,1,5,6};
quickSort(arry,0,arry.length - 1);
for (int i : arry) {
System.out.print(i+" ");
}
}
public void quickSort(int []arr,int left,int right){
int i = left;
int j = right;
int temp = arr[i];
// 是否进入递归
if(i < j){
// 判断是否完成一次快排
while(i < j){
while(arr[j] >= temp && i < j){
j--;
}
arr[i] = arr[j];
while(arr[i] < temp && i < j){
i++;
}
arr[j] = arr[i];
}
arr[i] = temp; //中间值赋值
if(i!=left)
quickSort(arr,left,i-1);
if(i!=right)
quickSort(arr,i+1,right);
}
}
- 第一章 java SE
- 1.1数据类型
- 1.2 流程控制语句
- 1.3 方法
- 1.4 面向对象三特性
- 1.5 对象数组与集合
- 1.6 数组和集合操作工具类
- 1.7 可变参数
- 1.8 String
- 1.9 StringBuilder
- 1.10 final&&finally&&finalize
- 1.11 抽象类与接口
- 1.12 基本数据类型的包装类
- 1.13 泛型
- 1.14 内部类
- 1.15 throw & throws & try catch
- 1.16 线程
- 1.17 BeanUtils
- 1.18 java反射
- 1.19 序列化和反序列化
- 1.20 IO输入输出流
- 1.21 File
- 1.22 RandomAccessFile
- 1.23 第三方工具CommonsIO
- 1.24 java网络传输
- 第二章 java EE
- 2.1 maven的配置
- 2.2 Cookie
- 2.3 EL表达式 JSTL
- 2.4 验证相关
- 2.4.1 验证码
- 2.5 防重复提交
- 2.6 activeMq的使用
- 2.7 jtl的使用
- 2.8 Upload上传文件
- 第三章 Spring相关
- 3.1 IOC/DI
- bean的生命周期
- bean的配置
- 3.2 Spring Aop
- 3.3 Spring Jdbc
- 3.4 事物相关
- 事物
- 事物的使用
- 3.5 MBG使用
- 第四章 解决问题方法
- 4.1 List转换为Map
- 4.2 结果返回类
- 4.3 HSSF的使用
- 第五章 排序
- 5.1 冒泡排序
- 5.2 选择排序
- 5.3 快速排序