代码实现:

  public static void sort(Comparable[] a) {
StdRandom.shuffle(a);//eliminate dependence on input
StdOut.print("After shuffle:");//for test
show(a);//for test
sort(a, 0, a.length-1);
} private static void sort(Comparable[] a, int lo, int hi) { if(hi <= lo + CUTOFF) {
if(hi > lo)
Insertion.sort(a, lo, hi);
return;
} int j = partition(a, lo, hi);
sort(a, lo, j-1);
sort(a, j+1, hi); }

单元测试:

package com.qiusongde;

import edu.princeton.cs.algs4.In;
import edu.princeton.cs.algs4.StdOut;
import edu.princeton.cs.algs4.StdRandom; public class QuickCutoffInsertion { private static int CUTOFF = 4;//default value is 8 public static void setCutoff(int cutoff) {
assert cutoff > 0;
CUTOFF = cutoff;
} public static void sort(Comparable[] a) {
StdRandom.shuffle(a);//eliminate dependence on input
StdOut.print("After shuffle:");//for test
show(a);//for test
sort(a, 0, a.length-1);
} private static void sort(Comparable[] a, int lo, int hi) { if(hi <= lo + CUTOFF) {
if(hi > lo)
Insertion.sort(a, lo, hi);
return;
} int j = partition(a, lo, hi);
sort(a, lo, j-1);
sort(a, j+1, hi); } private static int partition(Comparable[] a, int lo, int hi) { int i = lo;
int j = hi + 1;
Comparable v = a[lo]; StdOut.println();//for test
StdOut.printf("partition(input, %4d, %4d)\n", lo, hi);//for test while(true) {
while(less(a[++i], v))//find item larger or equal to v
if(i == hi)
break;
while(less(v, a[--j]));//not need to worry about j will be out of bound StdOut.println("i:" + i + " j:" + j);//for test if(i >= j)//cross
break; exch(a, i, j);
show(a);//for test
}
exch(a, lo, j); StdOut.printf("j is %4d\n", j);//for test
show(a);//for test return j; } private static void exch(Comparable[] a, int i, int j) { Comparable t = a[i];
a[i] = a[j];
a[j] = t; } private static boolean less(Comparable v, Comparable w) { return v.compareTo(w) < 0; } private static void show(Comparable[] a) { //print the array, on a single line.
for(int i = 0; i < a.length; i++) {
StdOut.print(a[i] + " ");
}
StdOut.println(); } public static boolean isSorted(Comparable[] a) { for(int i = 1; i < a.length; i++) {
if(less(a[i], a[i-1]))
return false;
} return true; } public static void main(String[] args) {
//Read strings from standard input, sort them, and print.
String[] a = In.readStrings();
show(a);//for test
sort(a);
assert isSorted(a);
show(a);//for test
} }

输出结果:

K R A T E L E P U I M Q C X O S
After shuffle:E R K U M C X A I O E S T P Q L partition(input, 0, 15)
i:1 j:10
E E K U M C X A I O R S T P Q L
i:2 j:7
E E A U M C X K I O R S T P Q L
i:3 j:5
E E A C M U X K I O R S T P Q L
i:4 j:3
j is 3
C E A E M U X K I O R S T P Q L Insertion.sort(input, 0, 2)
A C E E M U X K I O R S T P Q L partition(input, 4, 15)
i:5 j:15
A C E E M L X K I O R S T P Q U
i:6 j:8
A C E E M L I K X O R S T P Q U
i:8 j:7
j is 7
A C E E K L I M X O R S T P Q U Insertion.sort(input, 4, 6)
A C E E I K L M X O R S T P Q U partition(input, 8, 15)
i:15 j:15
j is 15
A C E E I K L M U O R S T P Q X partition(input, 8, 14)
i:14 j:14
j is 14
A C E E I K L M Q O R S T P U X partition(input, 8, 13)
i:10 j:13
A C E E I K L M Q O P S T R U X
i:11 j:10
j is 10
A C E E I K L M P O Q S T R U X Insertion.sort(input, 8, 9)
A C E E I K L M O P Q S T R U X Insertion.sort(input, 11, 13)
A C E E I K L M O P Q R S T U X
A C E E I K L M O P Q R S T U X

性能测试:

package com.qiusongde;

import edu.princeton.cs.algs4.StdOut;

public class Exercise2325 {

    public static void main(String[] args) {

        String alg = "QuickCutoffInsertion";

        int T = 10;//T trials

        for(int N = 1000; N <= 1000000; N *= 10){
StdOut.println("N:" + N);
for(int M = 0; M <= 30; M++) {
QuickCutoffInsertion.setCutoff(M);
double time = SortCompare.timeRandomInput(alg, N, T);
StdOut.printf("%8.4f", time);
}
StdOut.println();
} } }

输出结果:

N:1000
0.0050 0.0030 0.0060 0.0060 0.0060 0.0060 0.0060 0.0030 0.0010 0.0010 0.0030 0.0010 0.0020 0.0010 0.0020 0.0010 0.0000 0.0010 0.0010 0.0000 0.0020 0.0000 0.0020 0.0010 0.0020 0.0000 0.0020 0.0020 0.0000 0.0020 0.0000
N:10000
0.0200 0.0180 0.0140 0.0140 0.0130 0.0130 0.0140 0.0130 0.0120 0.0150 0.0130 0.0130 0.0100 0.0150 0.0120 0.0130 0.0130 0.0110 0.0120 0.0130 0.0150 0.0110 0.0120 0.0120 0.0150 0.0130 0.0130 0.0140 0.0140 0.0110 0.0150
N:100000
0.2070 0.2070 0.2010 0.1960 0.1970 0.1970 0.2040 0.2010 0.1800 0.1820 0.1820 0.1780 0.1790 0.1820 0.1800 0.1810 0.1850 0.1860 0.1750 0.1810 0.1810 0.1820 0.1790 0.1830 0.1810 0.1820 0.1840 0.1830 0.1830 0.1840 0.1830
N:1000000
3.9260 3.9100 3.9300 3.9050 3.8640 3.8250 3.7930 3.8780 3.8090 3.8360 3.7860 3.8530 3.8130 3.7770 3.7800 3.7570 3.8220 3.7800 3.8220 3.7850 3.7970 3.8020 3.8530 3.8340 3.8710 3.7660 3.8080 3.8580 3.8350 3.8890 3.7810

算法(Algorithms)第4版 练习 2.3.25的更多相关文章

  1. 1.2 Data Abstraction(算法 Algorithms 第4版)

    1.2.1 package com.qiusongde; import edu.princeton.cs.algs4.Point2D; import edu.princeton.cs.algs4.St ...

  2. 1.1 BASIC PROGRAMMING MODEL(算法 Algorithms 第4版)

    1.1.1 private static void exercise111() { StdOut.println("1.1.1:"); StdOut.println((0+15)/ ...

  3. ubuntu命令行下java工程编辑与算法(第四版)环境配置

    ubuntu命令行下java工程编辑与算法(第四版)环境配置 java 命令行 javac java 在学习算法(第四版)中的实例时,因需要安装配套的java编译环境,可是在编译java文件的时候总是 ...

  4. 配置算法(第4版)的Java编译环境

    1. 下载 1.1 JDK http://www.oracle.com/technetwork/java/javase/downloads/index.html选择“Windows x64 180.5 ...

  5. 算法(第四版)C# 习题题解——1.3.49 用 6 个栈实现一个 O(1) 队列

    因为这个解法有点复杂,因此单独开一贴介绍. 那么这里就使用六个栈来解决这个问题. 这个算法来自于这篇论文. 原文里用的是 Pure Lisp,不过语法很简单,还是很容易看懂的. 先导知识——用两个栈模 ...

  6. 在Eclipse下配置算法(第四版)运行环境

    第一步:配置Eclipse运行环境 Eclipse运行环境配置过程是很简单的,用过Eclipse进行java开发或学习的同学应该都很熟悉这个过程了. 配置过程: (1)系统环境:Windows7 64 ...

  7. 排序算法总结(C语言版)

    排序算法总结(C语言版) 1.    插入排序 1.1     直接插入排序 1.2     Shell排序 2.    交换排序 2.1     冒泡排序 2.2     快速排序 3.    选择 ...

  8. 算法(第四版)C#题解——2.1

    算法(第四版)C#题解——2.1   写在前面 整个项目都托管在了 Github 上:https://github.com/ikesnowy/Algorithms-4th-Edition-in-Csh ...

  9. 《算法》第四版 IDEA 运行环境的搭建

    <算法>第四版 IDEA 运行环境的搭建 新建 模板 小书匠 在搭建之初,我是想不到会出现如此之多的问题.我看了网上的大部分教程,都是基于Eclipse搭建的,还没有使用IDEA搭建的教程 ...

  10. 常见排序算法题(java版)

    常见排序算法题(java版) //插入排序:   package org.rut.util.algorithm.support;   import org.rut.util.algorithm.Sor ...

随机推荐

  1. JavaScript_DOM编程艺术第二版[阅]

    前两年迫于项目的需要,只是拿来JQuery用到项目中,并没有实质上理解javascript(貌似其他人也是这么干的)~ 随着最近几年,得益于Nodejs, React, Vue等,javascript ...

  2. u-boot-2014_04在TQ2440上的移植

    本文详细介绍了新版本的u-boot-2014_04在tq2440平台上的移植过程,期间参考了网上的其他移植文档,还有韦东山的移植uboot视频,讲的很好.下面是共享链接,欢迎下载,一同学习.其中有移植 ...

  3. CIA 读书笔记

    对此书的评价只有八个字:粗制滥造,到处粘贴. 对于通过表情识别人情绪的教程,最好要有图,图很重要,也最好有案例.

  4. 一、任天堂ns (Nintendo Switch) 上手

    公司不方便回家详解做个博客非专业评测~

  5. Spring整合JMS(消息中间件)

    这一节来说说,异步机制及spring对JMS封装 一.消息异步处理 类似于RMI.Hessian.Burlap等远程方法调用,它们都是同步的,所谓同步调用就是客户端必须等待操作完成,如果远程服务没有返 ...

  6. 速记const 指针与指向const的指针

    指向const的指针.它的意思是指针指向的内容是不能被改动的.它有两种写法. ` const int* p; (推荐) int const* p;` 再说const指针.它的意思是指针本身的值是不能被 ...

  7. XtraBackup备份mysql5.1.73

    一.基础介绍 mysql5.1在源码中配备了两个版本的innodb存储引擎源码:innobase和innodb_plugin,编译安装的时候可以通过参数--with-plugins=innobase, ...

  8. 划分Linux分区

    / Swap 这二个分区是必须有的. /usr linux系统都在 /usr 中 /home  用户信息都在 /home 下 /var 保持所有服务器的登录文件,且Web默认的路径在 /var中 可以 ...

  9. memcache 的使用

    基础知识 memcached 是一个开源项目,旨在利用多个服务器内的多余 RAM 来充当一个可存放经常被访问信息的内存缓存.这里的关键是使用了术语缓存:memcached 为加载自他处的信息提供的是内 ...

  10. Gone Fishing(贪心)

    Gone Fishing John is going on a fising trip. He has h hours available (1 ≤ h ≤ 16), and there are n ...