前几天实现了直接插入排序、冒泡排序和直接选择排序这三个基础排序。今天看了一下冒泡排序的改进算法,快速排序。单独记录一下,后面还有归并和基数排序等

快速排序

1.选择一个支点默认为数组第一个元素及array[start]作为支点,将所有大于支点元素的值放到支点后面,将所有小于支点元素的值放到支点前面,完成一次划分,返回支点的位置index

2.通过一个划分形成两个带排序的序列,[start, index - 1]和[index + 1, end]两个,在执行1直到序列元素只有1个则已经完成排序

具体解释和注意代码注释中有说明

QuickSort.java

 package com.gxf.sort;

 /**
* 这里实现快速排序
* 快速排序是对冒泡排序的一种改进
* 选数组中的一个元素作为支点,通常选第一个元素
* 将大于支点的元素放到支点后面,将小于支点的元素放到支点前面
* 这样一趟下来,支点前面的就是小于支点元素,支点后面的大于支点元素
* 每一趟划分,返回支点的位置,这样形成了两个带排序的数组,在分别对两个数组进行递归调用
* 直到每次划分只有一个元素
* @author Administrator
*
*/
public class QuickSort {
/**
* 这里是对数组的一趟划分,返回支点在数组中的位置,默认第一个元素为支点
* @param Rec
* @param start
* @param end
* @return
*/
public int quickSort(Rec rec[], int start,int end){
int fulcrum = rec[start].key;//fulcrum有道查的支点
int i = start;
int j = end;//分别指向开头和结束
while(i < j){//i==j时结束一次划分
while(i < j && rec[j].key > fulcrum)//找出右边比支点小的元素
j--;
rec[i].key = rec[j].key;//右边元素之间移到支点位置即可
while(i < j && rec[i].key < fulcrum)//找出左边比支点大的元素
i++;
rec[j].key = rec[i].key;//左边的大于支点元素之间交换过去
}
//这里要不要考虑相等元素的问题
rec[i].key = fulcrum;
return i;
} /**
* 对数组进行快速排序
* 递归实现
* @param rec
*/
public void sort(Rec rec[], int start, int end){
int index;
if(start < end){
index = quickSort(rec, start, end);
sort(rec, start, index - );
sort(rec, index + , end);//注意这里要+1要不然会无限递归,造成栈溢出
}
}
/**
* @param rec
*/
public void sort(Rec rec[]){
sort(rec, , rec.length - );
} }

Rec.java

 package com.gxf.sort;

 public class Rec {
public int key; public Rec(int key){
this.key = key;
}
public Rec(){ }
public void showArray(Rec rec[]){
for(int i = 0; i < rec.length ; i++){ System.out.print(rec[i].key + " ");
}
}
public Rec[] getRecArray(int array[]){
Rec result[] = new Rec[array.length];
for(int i = 0; i < array.length; i++){
result[i] = new Rec(array[i]);
}
return result;
}
}

Test.java

 package com.gxf.sort;

 public class Test {

     public static void main(String[] args) {
Rec rec = new Rec();
QuickSort quickSort = new QuickSort(); int array[] = new int[]{0, 32, 1, 34, 54, 5, 6};
Rec array_rec[] = rec.getRecArray(array);
System.out.println("使用快速排序之前的顺序:");
rec.showArray(array_rec); quickSort.sort(array_rec); System.out.println("使用快速排序之后的顺序:");
rec.showArray(array_rec);
} }

ps:这里主要参考了西电版的数据结构

快速排序QuickSort的更多相关文章

  1. 算法实例-C#-快速排序-QuickSort

    算法实例 ##排序算法Sort## ### 快速排序QuickSort ### bing搜索结果 http://www.bing.com/knows/search?q=%E5%BF%AB%E9%80% ...

  2. 快速排序(quicksort)算法实现

    快速排序(quicksort)是分治法的典型例子,它的主要思想是将一个待排序的数组以数组的某一个元素X为轴,使这个轴的左侧元素都比X大,而右侧元素都比X小(从大到小排序).然后以这个X在变换后数组的位 ...

  3. 归并排序(MergeSort)和快速排序(QuickSort)的一些总结问题

    归并排序(MergeSort)和快速排序(QuickSort)都是用了分治算法思想. 所谓分治算法,顾名思义,就是分而治之,就是将原问题分割成同等结构的子问题,之后将子问题逐一解决后,原问题也就得到了 ...

  4. json数据中的某一个字段进行快速排序quicksort

    快速排序(Quicksort)是对冒泡排序的一种改进,是一种分而治之算法归并排序的风格. 核心的思想就是通过一趟排序将要排序的数据分割成独立的两部分,其中一部分的所有数据都比另外一部分的所有数据都要小 ...

  5. 排序算法四:快速排序(Quicksort)

    快速排序(Quicksort),因其排序之快而得名,虽然Ta的平均时间复杂度也是O(nlgn),但是从后续仿真结果看,TA要比归并排序和堆排序都要快. 快速排序也用到了分治思想. (一)算法实现 pr ...

  6. 随手编程---快速排序(QuickSort)-Java实现

    背景 快速排序,是在上世纪60年代,由美国人东尼·霍尔提出的一种排序方法.这种排序方式,在当时已经是非常快的一种排序了.因此在命名上,才将之称为"快速排序".这个算法是二十世纪的七 ...

  7. 这个代码怎么改??Help快速排序 quicksort

    #include<stdio.h>int a[101],n;void quicksort(int left,int right){     int i,j,t,temp;     if(l ...

  8. C/C++ 快速排序 quickSort

    下面的动画展示了快速排序算法的工作原理. 快速排序图示:可以图中在每次的比较选取的key元素为序列最后的元素. #include <stdio.h> #include <stdlib ...

  9. 排序算法TWO:快速排序QuickSort

    import java.util.Random ; /** *快速排序思路:用到了分治法 * 一个数组A[0,n-1] 分解为三个部分,A[0,p - 1] , A[p] , A[p + 1, n-1 ...

随机推荐

  1. MyBatis学习系列二——增删改查

    目录 MyBatis学习系列一之环境搭建 MyBatis学习系列二——增删改查 MyBatis学习系列三——结合Spring 数据库的经典操作:增删改查. 在这一章我们主要说明一下简单的查询和增删改, ...

  2. static 在多台下的特性

    被static修饰的方法不具备多台的特性,因为这个时候,该方法已经不具备"后期绑定"的性质了,也就是说,基类的引用就算指向导出类,调用的static的方法还是用基类的. 如果要调用 ...

  3. Muzei Live Wallpaper壁纸应用安卓源码项目

    这个刚刚在安卓教程网那里看到的,这个是Muzei Live Wallpaper壁纸应用源码,这是已经在Playstore上线了的android壁纸应用,点击壁纸界面可以磨砂透明效果以及一般背景效果之间 ...

  4. ubuntu 12.04 64位设置兼容32位的实现

    在ubuntu12.04上,要运行32的程序,需要安装32位的兼容库. 以前在10.04上成功安装过,方法是 sudo apt-get install ia32-libs 但是在12.04上遇到了困难 ...

  5. Win 2003下IIS6+Mysql+php5.2  isapi搭建 升级php5.2到5.3测试 借助fastcgi实现

    Win 2003下IIS6+Mysql+php5.2  原环境isapi搭建 升级php5.2到5.3测试 借助fastcgi实现 操作如下 实验前准备:php-5.3.5-Win32-VC6-x86 ...

  6. Lua 多维表的遍历中的赋值

    说到Lua的遍历将要使用到循环:先说遍历再说循环: 遇到这样类似结构的一个table Data={ []={p1=,pa={,,}}, []={p1=,pa={,,}}, []={p1=,pa={,, ...

  7. C#通过WinAPI获取内存信息,32位64位可用

    using System;using System.Collections.Generic;using System.Linq;using System.Text;using System.Runti ...

  8. 7-ZIP实现数据高度压缩

    From:http://www.cnblogs.com/killerlegend/p/3746395.html Author:KillerLegend Date:2013.5.22 选中文件,鼠标右键 ...

  9. LinearRegression

    利用python实现简单的线性回归对房屋面积进行预测 # -*-coding:utf-8 -*- ''' Created on 2016年12月15日 @author: lpworkdstudy '' ...

  10. 在Silverlight宿主html页面添加按钮无法显示

    在建silverlight应用程序时宿主html中嵌入的silverlight时出现的问题: 预想效果: 实际效果: silverlight填满整个page的所以无法显示html中其他的控件 解决办法 ...