1.排序时,数组含有大量重复元素,应该使用哪种排序手段?

(1)mergeSort:与数组的特征无关,比较次数总是在1/2NlgN~NlgN之间

(2)quickSort:当所有的元素全都相同的时候,使用平方次时间

2.3-way  partitioning算法的目标:

将数组划分为3部分:

(1)lt和gt之间的元素等于v

(2)lt的左边元素小于v

(3)gt的右边元素大于v

3.Dijkstra的3-way partitioning算法:

(1)划分元素v是a[lo]

(2)scan i  from left to right

①a[i]<v:交换a[i]和a[lt],同时增大lt和i

②a[i]>v:交换a[i]和a[gt],减小gt

③a[i]==v:增大i(也就是不移动相等的元素)

i指向未遍历的元素,lt左边是比v小的,gt右边是比v大的,lt与i之间的是等于v的元素。

这个操作保证了等于v的元素 in place,接下来只需要分别对大于v和小于v的两个部分分别排序。

4.如果打乱数组,并且使用3-way partitioning,很多应用运行时间会是线性时间,会比mergesort快很多。

5.算法实现

  1. package com.cx.sort;
  2.  
  3. public class Quick3way {
  4. public static void sort(Comparable[] a) {
  5. //打乱数组
  6. Shuffling.sort(a);
  7. sort(a,0,a.length-1);
  8. }
  9.  
  10. public static void sort(Comparable[] a,int lo,int hi) {
  11. if(hi<=lo) return;
  12. int lt=lo,gt=hi,i=lo;
  13. Comparable v=a[lo];
  14. //只要i和gt不重叠就要继续进行
  15. //完成后,lt左边小于v,gt右边大于v,lt..gt等于v
  16. while(i<=gt) {
  17. int cmp=a[i].compareTo(v);
  18. //a[i]<v,交换a[lt]和a[i]
  19. if(cmp<0) exch(a, i++, lt++);
  20. //a[i]>v,交换a[i]和a[gt]
  21. else if(cmp>0) exch(a, i, gt--);
  22. //保证等于v的元素in place
  23. else i++;
  24. }
  25. //递归排序lt左侧和gt右侧部分
  26. sort(a, lo, lt-1);
  27. sort(a, gt+1, hi);
  28. }
  29.  
  30. private static boolean less(Comparable v,Comparable w) {
  31. return v.compareTo(w)<0;
  32. }
  33.  
  34. private static void exch(Comparable[] a,int i ,int j ) {
  35. Comparable t=a[i];
  36. a[i]=a[j];
  37. a[j]=t;
  38. }
  39. private static void show(Comparable[] a) {
  40. for(int i=0;i<a.length;i++) {
  41. System.out.print(a[i]+" ");
  42.  
  43. }
  44. System.out.println();
  45. }
  46. public static void main(String[] args) {
  47. String a[]= {"s","o","r","t","e","x","a","m","p","l","e"};
  48. show(a);
  49. sort(a);
  50. show(a);
  51. }
  52. }

2.5 3-way quickSort的更多相关文章

  1. quickSort算法导论版实现

    本文主要实践一下算法导论上的快排算法,活动活动. 伪代码图来源于 http://www.cnblogs.com/dongkuo/p/4827281.html // imp the quicksort ...

  2. Javascript算法系列之快速排序(Quicksort)

    原文出自: http://www.nczonline.net/blog/2012/11/27/computer-science-in-javascript-quicksort/ https://gis ...

  3. JavaScript 快速排序(Quicksort)

    "快速排序"的思想很简单,整个排序过程只需要三步: (1)在数据集之中,选择一个元素作为"基准"(pivot). (2)所有小于"基准"的元 ...

  4. QuickSort 快速排序 基于伪代码实现

    本文原创,转载请注明地址 http://www.cnblogs.com/baokang/p/4737492.html 伪代码 quicksort(A, lo, hi) if lo < hi p ...

  5. quicksort

    快排.... void quicksort(int *a,int left,int right){ if(left >= right){ return ; } int i = left; int ...

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

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

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

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

  8. python Quicksort demo

    __author__ = 'student' ''' quicksort step 1, choose one pivot, such as pivot=la[0] step 2, scan the ...

  9. 63.如何对单链表进行快排?和数组快排的分析与对比[quicksort of array and linked list]

    [本文链接] http://www.cnblogs.com/hellogiser/p/quick-sort-of-array-and-linked-list.html [题目] 单链表的特点是:单向. ...

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

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

随机推荐

  1. Linux终端下对话

    1.首先查看当前账户 [hadoop@weekend01 ~]$ who hadoop   tty1         2016-11-14 09:31 (:0) hadoop   pts/0      ...

  2. 安装SNMP

    http://songknight.blog.51cto.com/2599480/655337

  3. sql语句添加一列标示,然后进行分页。

    ,) , sum(Score) as Score ,Student_NO,Student_Name into #a2_tab from ksy_stu_ScoreInfo GROUP BY Stude ...

  4. TinyMCE编辑器

    TinyMCE编辑器下载地址   http://www.tinymce.com/download/download.php

  5. nodejs idea 创建项目 (一)

    1.在工作空间创建module file->new module next next 项目的目录结构: bin:跟业务无关的公共部分 node_modules :默认的模块 public:公共模 ...

  6. linux下php开启pdo扩展

    前提:网页报错 为解决问题:Undefined class constant 'MYSQL_ATTR_INIT_COMMAND' 解决方案 : 下载安装PHP_MYSQL扩展 wget http:// ...

  7. spring-mvc hello world (1)

    我学习一个程序,都是从DEMO开始的. 先不了解SPRING-MVC的原理,但一些小的概念还是需要了解的.由于之前有过SSH的工程经验,故基本的东东,不在叙述. 1.准备环境 JAR包:

  8. Win7系统32位和64位的区别

    Win7系统32位和64位的区别已经是一个老话题了,可是还是有很多朋友不明白.这两者到底有什么区别呢?下面本文与大家通俗的介绍下Win7系统32位和64位的区别,其他一些深入的理论讲述,大家可以看看文 ...

  9. SQL——时间戳

    mysql 低版本,date.datetime.timestamp 无法精确到毫秒 可以舍弃时间类型字段,用 bigint 来代替,如果用字符串类型代替,还是比较担心排序的时候只是根据第一个字母进行排 ...

  10. docker 容器挂载主机目录,访问出现 cannot open directory /mnt/home/webroot/: Permission denied 的解决办法

    问题原因及解决办法 原因是CentOS7中的安全模块selinux把权限禁掉了,至少有以下三种方式解决挂载的目录没有权限的问题: 1.在运行容器的时候,给容器加特权,及加上 --privileged= ...