快速排序

  • 快速排序原理

  快速排序(Quick Sort)的基本思想是,通过一趟排序将待排记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,则可对这两部分记录继续进行排序,以达到整个序列有序的目的。

  • 主程序
package Sort;

public class QuickSort {

	private void Qsort(int[] list, int low, int high){
int privot;
if(low < high) {
print(list);
/*算出枢轴值privot*/
privot = Partition(list, low, high);
/*对低子表递归排序*/
Qsort(list, low, privot-1);
/*对高子表递归排序*/
Qsort(list, privot+1, high);
}
} private int Partition(int[] list, int low, int high){
/*用表的第一个记录做枢轴记录*/
int privotkey = list[low];
while (low < high){
while (low < high && list[high] > privotkey)
high--;
/*将比枢轴记录小的记录交换到低端*/
swap(list, low, high);
while (low < high && list[low] < privotkey)
low++;
/*将比枢轴记录大的记录交换到高端*/
swap(list, low, high);
}
/*返回枢轴所在的位置*/
return low;
} private void swap(int [] list,int j, int i){
int temp;
temp = list[i];
list[i] = list[j];
list[j] = temp;
} private void print(int[] data) {
System.out.println("当前list数组的值:");
for (int i = 0; i < data.length; i++) {
System.out.print(data[i] + "\t");
}
System.out.println();
} public static void main(String[] args) {
int[] list = {50,40,80,30,60,70,10,90,20};
QuickSort qs = new QuickSort();
qs.Qsort(list, 0, list.length-1);
qs.print(list);
}
}

  

  • Qsort()分析
	private void Qsort(int[] list, int low, int high){
int privot;
if(low < high) {
print(list);
/*算出枢轴值privot*/
privot = Partition(list, low, high);
/*对低子表递归排序*/
Qsort(list, low, privot-1);
/*对高子表递归排序*/
Qsort(list, privot+1, high);
}
}

  

  • Partition()分析
	private int Partition(int[] list, int low, int high){
/*用表的第一个记录做枢轴记录*/
int privotkey = list[low];
while (low < high){
while (low < high && list[high] > privotkey)
high--;
/*将比枢轴记录小的记录交换到低端*/
swap(list, low, high);
while (low < high && list[low] < privotkey)
low++;
/*将比枢轴记录大的记录交换到高端*/
swap(list, low, high);
}
/*返回枢轴所在的位置*/
return low;
}

  

  • 输出结果
当前list数组的值:
50 40 80 30 60 70 10 90 20
当前list数组的值:
20 40 10 30 50 70 60 90 80
当前list数组的值:
10 20 40 30 50 70 60 90 80
当前list数组的值:
10 20 30 40 50 70 60 90 80
当前list数组的值:
10 20 30 40 50 60 70 90 80
当前list数组的值:
10 20 30 40 50 60 70 80 90

  

  • 时间复杂度分析

  最优情况下,快速排序算法的时间复杂度为O(nlogn),空间复杂度也为O(nlogn)

  • 单链表快速排序实现
/**
* Definition for singly-linked list.
* public class ListNode {
* int val;
* ListNode next;
* ListNode(int x) { val = x; }
* }
*/
public class Solution {
public ListNode sortList(ListNode head) {
if(head == null || head.next == null) return head; ListNode left = new ListNode(0), leftHead = left;
ListNode right = new ListNode(0), rightHead = right;
ListNode mid = new ListNode(0), midHead = mid;
int val = head.val; while(head != null) {
if(head.val < val) {
left.next = head;
left = head;
} else if(head.val > val) {
right.next = head;
right = head;
} else {
mid.next = head;
mid = head;
}
head = head.next;
} left.next = null;
right.next = null;
mid.next = null;
return merge(sortList(leftHead.next), midHead.next, sortList(rightHead.next));
} public ListNode merge(ListNode left, ListNode mid, ListNode right) {
ListNode leftTail = getTail(left);
ListNode midTail = getTail(mid);
midTail.next = right;
if(leftTail != null) {
leftTail.next = mid;
return left;
} else {
return mid;
}
} public ListNode getTail(ListNode head) {
if(head == null) return head;
while(head.next != null) {
head = head.next;
}
return head;
}
}

  

Java: 实现顺序表和单链表的快速排序的更多相关文章

  1. 【线性表基础】顺序表和单链表的插入、删除等基本操作【Java版】

    本文表述了线性表及其基本操作的代码[Java实现] 参考书籍 :<数据结构 --Java语言描述>/刘小晶 ,杜选主编 线性表需要的基本功能有:动态地增长或收缩:对线性表的任何数据元素进行 ...

  2. Java数据结构-线性表之单链表LinkedList

    线性表的链式存储结构,也称之为链式表,链表:链表的存储单元能够连续也能够不连续. 链表中的节点包括数据域和指针域.数据域为存储数据元素信息的域,指针域为存储直接后继位置(一般称为指针)的域. 注意一个 ...

  3. 线性表源码分享(c++),包含顺序表、单链表、循环链表、双向链表

    ---恢复内容开始--- 我是一个c++和数据结构的初学者,本文主要是把清华大学出版社的数据结构(用面向对象方法与c++语言描述)(第2版)这本书中第二章线性表的源码抄下来,在学习的过程中有助于加深印 ...

  4. 线性表 及Java实现 顺序表、链表、栈、队列

    数据结构与算法是程序设计的两大基础,大型的IT企业面试时也会出数据结构和算法的题目, 它可以说明你是否有良好的逻辑思维,如果你具备良好的逻辑思维,即使技术存在某些缺陷,面试公司也会认为你很有培养价值, ...

  5. java实现顺序表、链表、栈 (x)->{持续更新}

    1.java实现节点 /** * 节点 * @luminous-xin * @param <T> */ public class Node<T> { T data; Node& ...

  6. Java 实现简答的单链表的功能

    作者:林子木  博客网址:http://blog.csdn.net/wolinxuebin 參考网址:http://blog.csdn.net/sunsaigang/article/details/5 ...

  7. [数据结构 - 第3章] 线性表之单链表(C++实现)

    一.类定义 单链表类的定义如下: #ifndef SIGNALLIST_H #define SIGNALLIST_H typedef int ElemType; /* "ElemType类型 ...

  8. 线性表之单链表C++实现

    线性表之单链表 一.头文件:LinkedList.h //单链表是用一组任意的存储单元存放线性表的元素,这组单元可以是连续的也可以是不连续的,甚至可以是零散分布在内存中的任意位置. //单链表头文件 ...

  9. 数据结构(java版)学习笔记(三)——线性表之单链表

    单链表的优点: 长度不固定,可以任意增删. 单链表的缺点: 存储密度小,因为每个数据元素,都需要额外存储一个指向下一元素的指针(双链表则需要两个指针). 要访问特定元素,只能从链表头开始,遍历到该元素 ...

随机推荐

  1. SSL安全解决方案(转)

    http://blog.csdn.net/photnman/article/details/388853 背景及部分安全知识在高度保证应用程序安全的过程中我们不免会考虑到如下的安全需求,然后根据这些安 ...

  2. 在Delphi中实现HexToStr函数和StrToHex函数

    function TransChar(AChar: Char): Integer; begin '] then Result := Ord(AChar) - Ord(') else Result := ...

  3. android 76 使用get post方式提交数据

    get方式: package com.itheima.getmethod; import java.io.InputStream; import java.net.HttpURLConnection; ...

  4. 2014年最新720多套Android源码2.0GB免费一次性打包下载

    之前发过一个帖子,但是那个帖子有点问题我就重新发一个吧,下面的源码是我从今年3月份开始不断整理源码区和其他网站上的android源码,目前总共有720套左右,根据实现的功能被我分成了100多个类,总共 ...

  5. windows向ubuntu过渡之常用软件安装

    好久没有写博客了,介于最近上操作系统实验课,好多同学装上了ubuntu,网上的教程比较杂乱,下面我就总结分享一些安装完ubuntu要安装的常用软件,会持续更新... 1.搜狗拼音安装 (1)在安装输入 ...

  6. Linux命令后台执行技巧小结

    1.最简单的方法: command & 例如: top & 此时显示job编号和后台进程号 [] 2.正在运行的程序放入后台 Ctrl - Z 3.查看有哪些后台进程及状态 jobs ...

  7. 【锋利的jQuery】学习笔记02

    第二章 jQuery选择器 一.jQuery选择器的优势 写法简洁 $("div") 支持css2和css3选择器(对于css3选择器支持这一项,我认为应该是jQuery首先创造并 ...

  8. Devexpress 使用经验 —— ASPxGridView前后台交互写法推荐

    这里的格式是仁者见仁智者见智,这篇随笔只是我在工作过程中总结出的阅读性高,对我来说效率较高的写法. ASPX: <dx:ASPxGridView ID="ASPxGridViewLin ...

  9. Java获取项目路径

    参考博客.自己就不写了.我觉得他写得很详细 http://blog.csdn.net/hpf911/article/details/5852127

  10. ORACLE如何停止一个JOB

    ORACLE如何停止一个JOB1 相关表.视图2 问题描述为同事解决一个因为网络连接情况不佳时,执行一个超长时间的SQL插入操作.既然网络状况不好,就选择了使用一次性使用JOB来完成该插入操作.在JO ...