[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)这一行也有些年头了,但自老师 ...
随机推荐
- PINNs的网络大小与过拟合
PINNs中网络越大时,会不会产生过拟合呢 虽然PINNs可以不用到数据,但是我认为物理约束所带来的信息也是有限的 因此当网络变得很大时,也有可能产生过拟合现象吧 但是在神经元分裂那篇文章中,训练停滞 ...
- postgresql Extract 函数的使用
Extract 属于 SQL 的 DML(即数据库管理语言)函数,同样,InterBase 也支持 Extract,它主要用于从一个日期或时间型的字段内抽取年.月.日.时.分.秒数据,因此,它支持其关 ...
- 杨辉三角形实现过程详解-C语言基础
这一篇要探讨的是"杨辉三角形的实现以及如何人工走循环".涉及的知识点和内容很少,主要是想说明如何看懂循环,如何跟着循环走.属于C语言基础篇. 学习编程的人,在学习的初期,几乎都会接 ...
- 6、jmeter的配置元件:参数化--CSV文件
1.参数化一些数据,就需要用到csv文件 Filename:文件位置和文件名 (和jmeter同一个目录就不需要写哪个盘 直接写文件名字就可以了) File encoding:编码 Variable ...
- win10无管理员权限下以压缩包方式安装JDK8
使用场景:如果在没有管理员权限的情况下,无法运行.exe文件,可以使用这种方式安装,本次把JDK安装到D:\jdk-8u152 一:获取JDK8的压缩包 1.JDK8 华为镜像地址 2.将下载好的ex ...
- 打印机出现错误0x00000709要如何解决
就是微软2021年10月更新的这个补丁导致的 要卸载KB5006670. 原文:https://www.zhihu.com/question/298855357/answer/514515054 微软 ...
- 实验1.SDN拓扑实践
实验1:SDN拓扑实践 一.基本要求 (一)Mininet运行结果截图 (二) 使用Mininet的命令行生成如下拓扑: 1. 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线. 2. 3台 ...
- HAL层分析
1. 安卓HAL模块基本 2. 定义hal层代码的5个特性 1)硬件抽象层具有与硬件的密切相关性. 2) 硬件抽象层具有与操作系统无关性. 3) 接口定义的功能应该包含硬件或者系统所需硬件支持的所有功 ...
- 手把手带你玩转Linux
今天这篇文章带你走进Linux世界的同时,带你手把手玩转Linux,加深对Linux系统的认识. 一.搞好Linux工作必须得不断折腾,说白了,只是动手力量必须强.我在初学Linux的那片,家中三台计 ...
- 一天吃透Git面试八股文
什么是Git? Git是一个版本控制系统,用于跟踪计算机文件的变化.Git是一个跟踪计算机文件变化的版本控制系统,用于帮助协调一个项目中几个人的工作,同时跟踪一段时间的进展.换句话说,我们可以说它是一 ...