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. js中函数(方法)注释

    原文链接:https://blog.csdn.net/tianxintiandisheng/article/details/103764074 实例 /** * @function 处理表格的行 * ...

  2. scroll-view 横向滚动无效

    scroll-view的内层view元素需要: display: inline-block scroll-view的外层元素需要: white-space: nowrap 使得内部组件不换行.

  3. MySQL代替in之临时表

    如果我们正常的使用IN去查询 SELECT * FROM a JOIN b ON a.id = b.id WHERE b.tag_id IN (1,2,3,4,5,6) 这种因为in里面的参数是连续的 ...

  4. ABP vNext微服务架构详细教程——镜像推送

    1. Jenkins搭建 为实现容器化部署,我们需要将代码打包成镜像并推送至容器仓库,我们可以选择自建容器仓库或者使用公有云服务商提供的镜像仓库.这里我们使用阿里云提供的免费镜像仓库. 代码打包和镜像 ...

  5. 003Java的诞生

    003Java的诞生 1.计算机语言发展史 (1)第一代语言 机器语言 我们都知道计算机的基本计算方式都是基于二进制的方式. 二进制:010111001010110010110100 这种代码是直接输 ...

  6. Servlet的学习之路

    一.什么是什么Servlet? Java Servlet 是运行在 Web 服务器或应用服务器上的程序,它是作为来自 Web 浏览器或其他 HTTP 客户端的请求和 HTTP 服务器上的数据库或应用程 ...

  7. CSS函数var

    /*全局变量保存的地方*/ :root { --main-bg-color: red; /* 变量名必须以--开头 */ } var(custom-property-name, value) 值 描述 ...

  8. Python常见面试题013.请说出下面的代码返回结果是什么?

    013.请说出下面的代码返回结果是什么? *的坑:简单题 参考:https://docs.python.org/zh-cn/3.9/library/stdtypes.html#typesseq 示例代 ...

  9. 局部异常因子(Local Outlier Factor, LOF)算法详解及实验

    局部异常因子(Local Outlier Factor, LOF)通过计算样本点的局部相对密度来衡量这个样本点的异常情况,可以算是一类无监督学习算法.下面首先对算法的进行介绍,然后进行实验. LOF算 ...

  10. Android进度表示

    在连接上数据库之后,一切都变得简单了呢! 开心,很轻松地就能够将APP里面的相关内容写完啦! 尝试了好久的连接Mysql数据库,最后还是没有成功: 虽然Android studio里面自带的SQLit ...