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. Vue router前端路由配置以及实现tab切换

    vue router 安装:npm install vue-router或cnpm install vue-router或yarn add vue-router. 安装完成之后会在package.js ...

  2. js- throw

    // Create an object type UserExceptionfunction UserException (message){ this.message=message; this.n ...

  3. gpio 理解

    NVIC :NVIC_Init(&NVIC_Initsture); 1.NVIC只是设置某一种中断的优先级,而不是打开某种中断. 2.ppp_ITConfig():才是开/关具体某种中断使能位 ...

  4. 数据库之【常用sql语句归纳】

    一.数据库操作: 1.创建数据库 create database dbname; 2.创建库是否存在,不存在就创建 create database if not exists dbname; 3.查看 ...

  5. 2月26日Android学习

    今天下载了AndroidStudio,但是不知道为什么java文件一直显示file outside of source root,可能是部分文件没有安装的原因,等文件全部下载完之后再看看.

  6. 如何修改被编译后DLL文件 (转发)

    我们平时在工作中经常会遇到一些已经被编译后的DLL,而且更加麻烦是没有源代码可以进行修改,只能针对这个DLL的文件进行修改才能得到我们想要的结果:本文将通过一个实例来演示如果完成一个简单的修改;我们将 ...

  7. LeetCode 之 559. N叉树的最大深度

    原题链接 思路: 递归计算每个子树的深度,返回最大深度即可 python/python3: class Solution(object): def maxDepth(self, root): &quo ...

  8. MSSQL T-SQL 基础 (创建、增、删、改)

    1.创建数据库 create database StudentAchievementMS ----创建数据库,可以只执行此行来创建数据库,但以下属性都是默认 on primary --主数据文件 ( ...

  9. Docker 容器与镜像

    列出所有容器ID :docker ps -aq 查看所有运行或者不运行容器:docker ps -a 停止所有的container(容器),这样才能够删除其中的images:docker stop $ ...

  10. Sqoop连接数据库MySQL报错

    1.问题描述 (1)问题示例: [Hadoop@master TestDir]$ sqoop list-databases --connect jdbc:mysql://master:3306/ -- ...