快速排序算法(Java实现)
来源:互联网 发布:淘宝订单查询接口 编辑:程序博客网 时间:2024/06/10 19:27
1、基本思想
通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小,然后再按此方法对这两部分数据分别进行快速排序,整个排序过程可以递归进行,以此达到整个数据变成有序序列。
2、算法步骤
- 获得待排序数组
- 选取合适的数字作为排序基准数字(一般情况下选取数组或者子数组的第一个数字)。
- 将待排序数组中比基准数字小的放在基准数字的左边得到sub1,比基准数字大的放在基准数字的右边得到sub2。
- 如果sub1或者sub2只有一个元素,那么直接返回,否则就递归重排sub1或sub2。
3、Java代码实现
public class QuickSort { /** * @Comment 快速排序一 * @Author Ron * @Date 2017年10月25日 下午12:12:32 * @return */ static void quikSort(int[] sources,int leftIndex,int rightIndex){ if(leftIndex >= rightIndex){ //如果左下标大于等于右下标,证明排序后得到的子数组元素个数小于等于1,排序完成,直接返回 return; } int startIndex = boundary(sources,leftIndex,rightIndex); quikSort(sources,leftIndex,startIndex-1); quikSort(sources,leftIndex+1,rightIndex); } /** * @Comment 二分待排序数组 * @Author Ron * @Date 2017年10月25日 下午12:12:24 * @return */ static int boundary(int[] sources,int leftIndex,int rightIndex){ int startIndex=leftIndex; int endIndex = rightIndex; int baseNum = sources[leftIndex]; while (startIndex < endIndex) { while (startIndex < endIndex && sources[endIndex] >= baseNum) { endIndex--; } sources[startIndex]=sources[endIndex]; while (startIndex < endIndex && sources[startIndex] <= baseNum) { startIndex++; } sources[endIndex]=sources[startIndex]; } sources[startIndex]=baseNum; return startIndex; } public static void main(String[] args) { int[] sources={3,9,4,1,7,6,2,0,8}; quikSort(sources,0,sources.length-1); String result=""; for(int i = 0 ; i < sources.length ; i++){ result += sources[i]+" "; } System.out.println(result); }}
阅读全文
0 0
- java实现快速排序算法
- java实现快速排序算法
- 算法-快速排序-java实现
- 快速排序算法Java实现
- java算法实现快速排序
- java实现快速排序算法
- 快速排序算法-java实现
- 快速排序算法Java实现
- 快速排序算法java实现
- java实现快速排序算法
- Java实现快速排序算法
- 快速排序算法Java实现
- Java实现快速排序算法
- 快速排序算法java实现
- java实现快速排序算法
- Java 实现快速排序算法
- 快速排序算法java实现
- java实现快速排序算法
- 做了8年电商 我发现这6种靠谱的电商运营管理思维
- es6-数组扩展
- Eclipse运行Android项目提示sdk\build-tools\26.0.0\lib\dx.jar Unable to build: the file dx.jar was not loade
- liunx中,mysql插入,查询乱码,临时解决方案
- viewpager+fragment 切换
- 快速排序算法(Java实现)
- handler最简单的倒计时
- jsp中 jstl el c标签混合使用
- Python基础入门之变量和数据类型一
- 对2-9取余的计算方法
- as 导入项目时无需更新gradle
- linux上传文件命令-rz
- contos7 更换阿里云yum源
- RandomUtil