八大种必知排序算法(一) 冒泡排序、快速排序 (续)
来源:互联网 发布:php 获取上传文件 编辑:程序博客网 时间:2024/06/05 20:11
代码实现如下:
1.查找中轴(最低位作为中轴)所在位置
/*** 查找出中轴(默认是最低位low)的在numbers数组排序后所在位置
*
* @param numbers 带查找数组
* @param low 开始位置
* @param high 结束位置
* @return 中轴所在位置
*/
public static int getMiddle(int[] numbers, int low,int high)
{
int temp = numbers[low]; //数组的第一个作为中轴
while(low < high)
{
while(low < high && numbers[high] > temp)
{
high--;
}
numbers[low] = numbers[high];//比中轴小的记录移到低端
while(low < high && numbers[low] < temp)
{
low++;
}
numbers[high] = numbers[low] ; //比中轴大的记录移到高端
}
numbers[low] = temp ; //中轴记录到尾
return low ; // 返回中轴的位置
}
2、 递归形式的分治排序算法:
/***
* @param numbers 带排序数组
* @param low 开始位置
* @param high 结束位置
*/
public static void quickSort(int[] numbers,int low,int high)
{
if(low < high)
{
int middle = getMiddle(numbers,low,high); //将numbers数组进行一分为二
quickSort(numbers, low, middle-1); //对低字段表进行递归排序
quickSort(numbers, middle+1, high); //对高字段表进行递归排序
}
}
3、快速排序提供方法调用
/*** 快速排序
* @param numbers 带排序数组
*/
public static void quick(int[] numbers)
{
if(numbers.length > 0) //查看数组是否为空
{
quickSort(numbers, 0, numbers.length-1);
}
}
分析:
快速排序是通常被认为在同数量级(O(nlog2n))的排序方法中平均性能最好的。但若初始序列按关键码有序或基本有序时,快排序反而蜕化为冒泡排序。为改进之,通常以“三者取中法”来选取基准记录,即将排序区间的两个端点与中点三个记录关键码居中的调整为支点记录。快速排序是一个不稳定的排序方法。
方法测试
打印函数:
public static void printArr(int[] numbers){
for(int i = 0 ; i < numbers.length ; i ++ )
{
System.out.print(numbers[i] + ",");
}
System.out.println("");
}
测试:
{
int[] numbers = {10,20,15,0,6,7,2,1,-5,55};
System.out.print("排序前:");
printArr(numbers);
bubbleSort(numbers);
System.out.print("冒泡排序后:");
printArr(numbers);
quick(numbers);
System.out.print("快速排序后:");
printArr(numbers);
}
结果:
排序前:10,20,15,0,6,7,2,1,-5,55,冒泡排序后:-5,0,1,2,6,7,10,15,20,55,快速排序后:-5,0,1,2,6,7,10,15,20,55,
选择排序、插入排序、希尔排序可查看:http://www.cnblogs.com/0201zcr/p/4764427.html
归并排序、堆排序可查看:http://www.cnblogs.com/0201zcr/p/4764705.html
0 0
- 八大种必知排序算法(一) 冒泡排序、快速排序 (续)
- 必须知道的八大种排序算法【java实现】(一) 冒泡排序、快速排序
- 必须知道的八大种排序算法【java实现】(一) 冒泡排序、快速排序
- 八大排序算法总结之一(冒泡排序,快速排序,直接插入排序,希尔排序)
- 八大排序算法总结之一(冒泡排序,快速排序,直接插入排序,希尔排序)
- 八大排序算法(五)冒泡排序
- 八大排序算法(5) 冒泡排序
- php实现排序算法(一) 冒泡排序 快速排序
- 八大排序算法(六)快速排序
- 八大排序算法(六) 快速排序
- 八大排序算法(一)
- 八大排序算法-冒泡排序
- 八大排序算法-冒泡排序
- 从零开始学算法(一)排序算法(桶排序、冒泡排序、快速排序)
- 排序算法----交换排序(冒泡排序,快速排序)
- 算法排序-交换排序(冒泡排序,快速排序)
- 八大排序算法之(五)冒泡排序
- 排序算法(冒泡、快速)
- OpenCV Mat数据类型及位数总结
- MySQL单表百万数据记录分页性能优化
- tomcat 工程路径问题
- 天声人語 20150909
- javax.persistence包
- 八大种必知排序算法(一) 冒泡排序、快速排序 (续)
- OpenWrt启动脚本分析
- Ubuntu adb 连接手机
- Git提交项目到Github
- LA3942(Trie)
- Android读取sql文件并导入数据库
- Error: Activity class {package1/package2.mainActivity} does not exist.
- HDU 1011 Starship Troopers(树形DP)
- 日经春秋 20150909