快速排序

  • 快速排序原理

  快速排序(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. 解析xlsx与xls--使用2012poi.jar

    1.导入Jar包:poi-3.8-20120326.jar.poi-ooxml-3.8-20120326.jar.poi-ooxml-schemas-3.8-20120326.jar.xbean.ja ...

  2. Sae 上传文件到Storage

    首先说一下几个地方: 1.上传使用ss.upload("domin域名","源地址","目标地址,也就是storage的地址");假设要上传 ...

  3. struts2之入门login

    1.struts 最小开发需要的jar有: struts2-core-2.2.3.jar :Struts 2框架的核心类库 xwork-core-2.2.3.jar :XWork类库,Struts 2 ...

  4. xcode语法高亮插件

    转自http://www.cocoachina.com/bbs/read.php?tid=150107 首先感谢该楼主的亲情贡献@不胜感激! 在Xcode4.6.3中,我使用如下方法放到Plugins ...

  5. Java Stax操作XML简介

    使用stax操作xml 非常的简单,它的读取过程像是一个光标在移动.针对不同的节点做不同的处理. 先看一个基于光标的模型处理xml: public class StaxTest { @Test pub ...

  6. Java基础知识强化之集合框架笔记63:Map集合之HashMap嵌套ArrayList

    1. ArrayList集合嵌套HashMap集合并遍历. 需求:假设ArrayList集合的元素是HashMap.有3个.每一个HashMap集合的键和值都是字符串.元素我已经完成,请遍历. 结果: ...

  7. 使用 git 进行项目管理(只管理代码,不管理项目配置)

    使用Git进行项目管理 1. 从服务器pull项目,本地还原工程 从服务器拉取仓库及分支 git clone git@github.com/helloWorld.git git branch -a g ...

  8. 使用httpModule做权限系统

    页面请求过程: 根据这个流程,网上一般的权限验证在:Http.Module.AuthorizeRequestHttp.Module.PreRequestHandlerExecute 例如使用前者: u ...

  9. 上传jar包到nexus私服

    摘要 通过网页和maven两种方式,上传本地的jar到nexus私服,以及引用jar时,自动引用依赖 1通过网页上传 这种方法只是上传了jar包.通过maven引用当前jar,不能取得jar的依赖   ...

  10. css修改li前面的小圆点的颜色

    直接改 li 的style 的 color 就好:就是这样:over