Discussão da tarefa T01 (layout)
Maratona de instalação do ambiente de programação do livro de Sedgewick e Wayne.
'.:/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 baixado do website do livro de Sedgewick e Wayne. (No caso do Windows, o instalador algs4.exe faz isso para você automaticamente.)
% checkstyle MeuPrograma.java % javac MeuPrograma.java % findbugs MeuPrograma.class ADT1.class ADT2.class
% java MeuPrograma argumento argumento ...
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
% more tinyW.txt 84 48 68 10 18 98 12 23 54 57 48 33 16 77 11 29
(No Linux, experimente usar cat e less no lugar de more. No Windows, experimente type.)
Repita com largeW.txt e largeT.txt.