O website do livro de Sedgewick e Wayne tem uma rica biblioteca de classes Java que inclui todos os programas discutidos no livro. Também inclui muitos arquivos de dados interessantes.
'.:/home/XXX/algs4/stdlib.jar:/home/XXX/algs4/algs4.jar'
e no Windows é
".;C:\Users\XXX\algs4\algs4.jar;C:\Users\XXX\algs4\stdlib.jar"
sendo XXX/algs4/ o diretório onde você colocou o material que baixou do website do livro. (No caso do Windows, o instalador algs4.exe faz isso para você automaticamente.)
% checkstyle *.java
(o %
indica o prompt do computador).
% javac *.java
% findbugs *.class
% java MeuPrograma argumento1 argumento2 ...
% more tinyW.txt 84 48 68 10 18 98 12 23 54 57 48 33 16 77 11 29
import java.util.Arrays;
public class BinarySearch {
public static int rank(int key, int[] a) {
int lo = 0;
int hi = a.length - 1;
while (lo <= hi) {
int mid = lo + (hi - lo) / 2;
if (key < a[mid]) hi = mid - 1;
else if (key > a[mid]) lo = mid + 1;
else return mid;
}
return -1;
}
public static void main(String[] args) {
In in = new In(args[0]);
int[] whitelist = in.readAllInts();
Arrays.sort(whitelist);
while (!StdIn.isEmpty()) {
int key = StdIn.readInt();
if (rank(key, whitelist) == -1)
StdOut.println(key);
}
}
}
% javac BinarySearch.java % java BinarySearch tinyW.txt < tinyT.txt 50 99 13
Repita com largeW.txt e largeT.txt.