JAVA常用排序算法之快速排序
来源:互联网 发布:cf一键瞬狙数据 编辑:程序博客网 时间:2024/05/16 14:49
JAVA常用排序算法之快速排序。
快速排序是冒泡排序的一种改进,要求排序速度较快。同样,这也是一种不稳定的算法。
具体的实现方式如下:首先设定一个初始值,然后进行比较,大于初始值的放在左边,小于初始值的放在右边,然后递归的进行左边和右边的比较。
算法的平均时间复杂度为O(n×log2(n))。
实现的代码如下:
public class Demo6 { /** * 常用排序算法之快速排序 */ public static void main(String[] args) { int[]arr={5,89,6,79,102,1}; int start=0; int end=arr.length-1; quicksort(arr,start,end); printarr(arr); } public static void quicksort(int[]arr,int start,int end){ if (start<end) { //将第一个值设置为基准值 int base=arr[start]; int index=start; //设定开头和结尾(一般习惯用新的定量去变换,原有的还要用的变量会保留) int i=start; int j=end; //设定一个值用于进行交换 int temp=0; while(i<j){ //从后向前扫描 如果有比基准值小的就交换(因为基准值是第一个所以要从后向前) while(arr[j]>base&&j>i){ j--; } //有比基准小的就交换 arr[index]=arr[j]; arr[j]=base; index=j; //从前向后扫描 如果有比基准值大的就交换 while(arr[i]<base&&j>i){ i++; } //有比基准大的就交换 arr[index]=arr[i]; arr[i]=base; index=i; } //然后进行迭代 if (index>start) { quicksort(arr,start,index-1); } if (index<end){ quicksort(arr,index+1,end); } } } public static void printarr(int[]arr){ for (int i : arr) { System.out.print(i+" "); } } }
阅读全文
0 0
- Java常用排序算法之快速排序
- JAVA常用排序算法之快速排序
- Java常用算法之快速排序
- java常用算法之快速排序详解
- 常用排序算法之快速排序算法
- 常用算法之-快速排序
- 常用算法之快速排序
- 常用排序算法之快速排序
- 常用排序算法之快速排序
- 常用排序算法之快速排序
- 常用排序算法之快速排序
- 常用排序算法之快速排序
- 常用排序算法之快速排序
- 【算法】常用算法之快速排序算法
- java算法之快速排序
- java算法之快速排序
- Java算法之快速排序
- java算法之快速排序
- gulp介绍及less插件详解
- okyo Cabinet简介
- 【机器学习】利用蚁群算法求解旅行商(TSP)问题
- Android O体验系列(一)Android Studio2.4预览版的使用及项目使用配置方式
- 离散题目15
- JAVA常用排序算法之快速排序
- android fragment 生命周期引起的错误及思考
- 如何提高网页的打开速度
- NancyFx 2.0的开源框架的使用-AspnetBootstrapping
- centos7 配置本地IP地址
- lintcode(608)Two Sum
- 测试项目规范及管理
- Java基础第1讲--Java关键字和标识符
- ospf学习-----ospf网络类型、拓扑类型