1 快速排序

1.1 算法思想

快速排序是由冒泡排序改进而得的。

在冒泡排序过程中,只对相邻的2个记录进行比较;因此,每次交换2个相邻记录时,只能消除1个逆序。

若能通过2个(不相邻)记录的1次交换,消除多个逆序,则:会大大加快排序的速度。

而快速排序方法中的1次交换,则:可能消除多个逆序。

1.2 算法特征

  • 属于【交换排序】的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较大/无序/仅顺序存储)的更多相关文章

  1. Java排序算法之快速排序

    Java排序算法之快速排序 快速排序(Quicksort)是对冒泡排序的一种改进. 快速排序由C. A. R. Hoare在1962年提出.它的基本思想是:通过一趟排序将要排序的数据分割成独立的两部分 ...

  2. 算法相关——Java排序算法之快速排序(三)

    0. 前言 本系列文章将介绍一些常用的排序算法.排序是一个非常常见的应用场景,也是开发岗位面试必问的一道面试题,有人说,如果一个企业招聘开发人员的题目中没有排序算法题,那说明这个企业不是一个" ...

  3. java排序算法-交换排序

    public class ExchangeSortUtils { // 冒泡 public static void bubbleSort(int[] array) { int length = arr ...

  4. java排序算法(五):快速排序

    java排序算法(五):快速排序 快速排序是一个速度非常快的交换排序算法,它的基本思路很简单,从待排的数据序列中任取一个数据(如第一个数据)作为分界值,所有比它小的元素放到左边.所有比它大的元素放到右 ...

  5. Java常见排序算法之快速排序

    在学习算法的过程中,我们难免会接触很多和排序相关的算法.总而言之,对于任何编程人员来说,基本的排序算法是必须要掌握的. 从今天开始,我们将要进行基本的排序算法的讲解.Are you ready?Let ...

  6. java排序算法之冒泡排序和快速排序

    总结一下Java排序算法,以便记忆. 各类排序的时间复杂度: 排序方法 时间复杂度(平均) 时间复杂度(最坏) 时间复杂度(最好) 空间复杂度 稳定性 复杂性 直接插入排序 O(n2)O(n2) O( ...

  7. 排序算法之快速排序Java实现

    排序算法之快速排序 舞蹈演示排序: 冒泡排序: http://t.cn/hrf58M 希尔排序:http://t.cn/hrosvb  选择排序:http://t.cn/hros6e  插入排序:ht ...

  8. java排序算法(一):概述

    java排序算法(一)概述 排序是程序开发中一种非常常见的操作,对一组任意的数据元素(活记录)经过排序操作后,就可以把它们变成一组按关键字排序的一组有序序列 对一个排序的算法来说,一般从下面三个方面来 ...

  9. 常用Java排序算法

    常用Java排序算法 冒泡排序 .选择排序.快速排序 package com.javaee.corejava; public class DataSort { public DataSort() { ...

  10. Python之排序算法:快速排序与冒泡排序

    Python之排序算法:快速排序与冒泡排序 转载请注明源地址:http://www.cnblogs.com/funnyzpc/p/7828610.html 入坑(简称IT)这一行也有些年头了,但自老师 ...

随机推荐

  1. PINNs的网络大小与过拟合

    PINNs中网络越大时,会不会产生过拟合呢 虽然PINNs可以不用到数据,但是我认为物理约束所带来的信息也是有限的 因此当网络变得很大时,也有可能产生过拟合现象吧 但是在神经元分裂那篇文章中,训练停滞 ...

  2. postgresql Extract 函数的使用

    Extract 属于 SQL 的 DML(即数据库管理语言)函数,同样,InterBase 也支持 Extract,它主要用于从一个日期或时间型的字段内抽取年.月.日.时.分.秒数据,因此,它支持其关 ...

  3. 杨辉三角形实现过程详解-C语言基础

    这一篇要探讨的是"杨辉三角形的实现以及如何人工走循环".涉及的知识点和内容很少,主要是想说明如何看懂循环,如何跟着循环走.属于C语言基础篇. 学习编程的人,在学习的初期,几乎都会接 ...

  4. 6、jmeter的配置元件:参数化--CSV文件

    1.参数化一些数据,就需要用到csv文件 Filename:文件位置和文件名 (和jmeter同一个目录就不需要写哪个盘 直接写文件名字就可以了) File  encoding:编码 Variable ...

  5. win10无管理员权限下以压缩包方式安装JDK8

    使用场景:如果在没有管理员权限的情况下,无法运行.exe文件,可以使用这种方式安装,本次把JDK安装到D:\jdk-8u152 一:获取JDK8的压缩包 1.JDK8 华为镜像地址 2.将下载好的ex ...

  6. 打印机出现错误0x00000709要如何解决

    就是微软2021年10月更新的这个补丁导致的 要卸载KB5006670. 原文:https://www.zhihu.com/question/298855357/answer/514515054 微软 ...

  7. 实验1.SDN拓扑实践

    实验1:SDN拓扑实践 一.基本要求 (一)Mininet运行结果截图 (二) 使用Mininet的命令行生成如下拓扑: 1. 3台交换机,每个交换机连接1台主机,3台交换机连接成一条线. 2. 3台 ...

  8. HAL层分析

    1. 安卓HAL模块基本 2. 定义hal层代码的5个特性 1)硬件抽象层具有与硬件的密切相关性. 2) 硬件抽象层具有与操作系统无关性. 3) 接口定义的功能应该包含硬件或者系统所需硬件支持的所有功 ...

  9. 手把手带你玩转Linux

    今天这篇文章带你走进Linux世界的同时,带你手把手玩转Linux,加深对Linux系统的认识. 一.搞好Linux工作必须得不断折腾,说白了,只是动手力量必须强.我在初学Linux的那片,家中三台计 ...

  10. 一天吃透Git面试八股文

    什么是Git? Git是一个版本控制系统,用于跟踪计算机文件的变化.Git是一个跟踪计算机文件变化的版本控制系统,用于帮助协调一个项目中几个人的工作,同时跟踪一段时间的进展.换句话说,我们可以说它是一 ...