[Java]排序算法>交换排序>【快速排序】(O(N*logN)/不稳定/N较大/无序/仅顺序存储)
1 快速排序
1.1 算法思想
快速排序是由冒泡排序改进而得的。
在冒泡排序过程中,只对相邻的2个记录进行比较;因此,每次交换2个相邻记录时,只能消除1个逆序。
若能通过2个(不相邻)记录的1次交换,消除多个逆序,则:会大大加快排序的速度。
而快速排序方法中的1次交换,则:可能消除多个逆序。
1.2 算法特征
- 属于【交换排序】的1种
- 适用于【稳定性】:不稳定
- 适用于【规模N】:较大
- 适用于【有序性】:无序
- 适用于【存储结构】:顺序存储结构(链式存储结构难以实现)
- 【时间复杂度】:O(nlogn)(最好) / O(nlogn)(平均) / O(n*n)(最坏)
- 【空间复杂度】:O(logn) (最好) / ------------- / O(n) (最坏)
- 相关口诀:
- 【(选)希堆快】不稳定,【二希堆快】顺序存,【归堆快】时NlogN
1.3 算法实现
import java.util.*;
public class QuickSort {
private static void quickSortOfJDK(int[] array, int left, int right) {//JDK的快速排序
for (int i = left, j = i; i < right; ) {
int tmp = array[i + 1];
while (array[j] < tmp) {//不符合升序
array[j + 1] = array[j];
if (j-- == left) {
break;
}
}
array[j + 1] = tmp;
i = i + 1;
j = i;
}
}
private static int partition(int[] array, int low, int high) {
int pivotValue = array[low]; //将第1(low)个元素所处位置空置起来,方便交换;且以第1个元素作为 分割标准值
while (low < high) {
while (low < high && pivotValue < array[high]) {
high--;
}//step2 使右边的序列元素均大于pivot
array[low] = array[high]; //将此时不满足上述条件的high处值 移至 事先空置的 low 处存储 (则 high处空置)
while (low < high && pivotValue > array[low]) {
low++;
}//step3 使左边的序列元素均小于pivot
array[high] = array[low];//将此时不满足上述条件的low处值 移至 事先空置的 high 处存储
}
//不满足 low < high时: 即 此时 pivot的两边已排序完毕
array[low] = pivotValue;
return low;
}
private static void sort(int[] array, int left, int right) {
if (left < right) {
int pivot = partition(array, left, right); //step1 选定中心轴/分节符【pivot】
sort(array, left, pivot - 1);
sort(array, pivot + 1, right);
}
}
public static int[] quickSort(int[] array) {
int left = 0, right = array.length - 1;
int[] resultArray = Arrays.copyOfRange(array, 0, array.length);
sort(resultArray, left, right);
return resultArray;
}
}
1.4 测试实现
import java.util.Scanner;
public class Main {
public static void print(int[] array){
if(array==null || array.length<1){
return;
}
for(int i=0;i<array.length-1;i++){
System.out.print(array[i]+" ");
}
System.out.println(array[array.length-1]);
}
public static void main(String[] args) {
//1 输入 一组 乱序的数值 数组
Scanner scanner = new Scanner(System.in);
String input = scanner.nextLine();
String [] strValues = input.trim().split(" ");
int [] array = new int[strValues.length];
for(int i=0,len=strValues.length;i<len;i++){
array[i] = Integer.valueOf(strValues[i]).intValue();//假定所有输入均为合规的整型数值
}
// print(array);// test - 输出 所输入的数据
//2 排序
int [] sortedArray = QuickSort.quickSort(array);//快速排序
//3 输出
print(sortedArray);
}
}
//console - input↓
3 6 5 8 9 4 2 7
//console - output↓
2 3 4 5 6 7 8 9
1.5 参考文献
- 《数据结构(C语言-第2版-严蔚敏 吴伟民 著)》:Page242
[Java]排序算法>交换排序>【快速排序】(O(N*logN)/不稳定/N较大/无序/仅顺序存储)的更多相关文章
- Java排序算法之快速排序
Java排序算法之快速排序 快速排序(Quicksort)是对冒泡排序的一种改进. 快速排序由C. A. R. Hoare在1962年提出.它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分 ...
- 算法相关——Java排序算法之快速排序(三)
0. 前言 本系列文章将介绍一些常用的排序算法.排序是一个非常常见的应用场景,也是开发岗位面试必问的一道面试题,有人说,如果一个企业招聘开发人员的题目中没有排序算法题,那说明这个企业不是一个" ...
- java排序算法-交换排序
public class ExchangeSortUtils { // 冒泡 public static void bubbleSort(int[] array) { int length = arr ...
- java排序算法(五):快速排序
java排序算法(五):快速排序 快速排序是一个速度非常快的交换排序算法,它的基本思路很简单,从待排的数据序列中任取一个数据(如第一个数据)作为分界值,所有比它小的元素放到左边.所有比它大的元素放到右 ...
- Java常见排序算法之快速排序
在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...
- java排序算法之冒泡排序和快速排序
总结一下Java排序算法,以便记忆. 各类排序的时间复杂度: 排序方法 时间复杂度(平均) 时间复杂度(最坏) 时间复杂度(最好) 空间复杂度 稳定性 复杂性 直接插入排序 O(n2)O(n2) O( ...
- 排序算法之快速排序Java实现
排序算法之快速排序 舞蹈演示排序: 冒泡排序: http://t.cn/hrf58M 希尔排序:http://t.cn/hrosvb 选择排序:http://t.cn/hros6e 插入排序:ht ...
- java排序算法(一):概述
java排序算法(一)概述 排序是程序开发中一种非常常见的操作,对一组任意的数据元素(活记录)经过排序操作后,就可以把它们变成一组按关键字排序的一组有序序列 对一个排序的算法来说,一般从下面三个方面来 ...
- 常用Java排序算法
常用Java排序算法 冒泡排序 .选择排序.快速排序 package com.javaee.corejava; public class DataSort { public DataSort() { ...
- Python之排序算法:快速排序与冒泡排序
Python之排序算法:快速排序与冒泡排序 转载请注明源地址:http://www.cnblogs.com/funnyzpc/p/7828610.html 入坑(简称IT)这一行也有些年头了,但自老师 ...
随机推荐
- html-list
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- 2003031120—廖威—Python数据分析五一假期作业
项目 要求 课程班级博客链接 20级数据班(本) 这个作业要求链接 Python数据分析五一假期作业 博客名称 2003031120-廖威-Python数据分析五一假期作业 要求 每道题要有题目,代码 ...
- oracle 将以逗号分隔的列拆成多行的的方法
原表如下 select * from hs_acct.custattach a where a.client_id='888827395'; 将列拆分成多行的语句 select * from ( -- ...
- FlexPaperViewer跨服务器\跨域访问swf不显示问题
做在线预览办公文档时,遇到了使用flexpaper访问文件服务器swf不显示问题. 假想1: swf文件有问题? 实验1: 直接访问swf文件在文件服务器的地址,浏览器可以正常访问,但是放在flexp ...
- 2020.4.28关于pta的总结
0.前言 这次作业针对的是oo程序设计第二单元(5-8周)的作业,在整体当中属于第4到第6次作业. 此三次作业的知识要点为:继承类,多态性,字符串,结构类,接口类. 此三次作业的时间为20.4.12- ...
- Apache Ranger系列九:修改源码支持URI类型为s3的操作
问题描述:ranger在checkPrivileges(org.apache.ranger.authorization.hive.authorizer.RangerHiveAuthorizer)时,当 ...
- c# 数组 集合 属性访问 设置
当只修改数组或者集合的某一个特定值时不会经过CLR属性封装器
- 钉钉获取第三方token时提示签名时间戳参数超时的处理方法
今天在更新平台功能时,碰到一个问题,从钉钉跳转到平台,始终不能成功.查看日志发现,出现了 签名时间戳参数超时 的错误. 想着没有动过相对应的代码,应该不是代码的问题. 查询官方文档,没有给出明确的答复 ...
- 详解数仓中sequence的应用场景及优化
摘要:本文简单介绍sequence的使用场景及如何修改sequence的cache值提高性能. 本文分享自华为云社区<GaussDB(DWS)关于sequence的那些事>,作者:Arro ...
- Hadoop-HA节点介绍
设计思想 hadoop2.x启用了主备节点切换模式(1主1备) 当主节点出现异常的时候,集群直接将备用节点切换成主节点 要求备用节点马上就要工作 主备节点内存几乎同步 有独立的线程对主备节点进行监控健 ...