// // This file contains the Java code from Program 14.6 of // "Data Structures and Algorithms // with Object-Oriented Design Patterns in Java" // by Bruno R. Preiss. // // Copyright (c) 1998 by Bruno R. Preiss, P.Eng. All rights reserved. // // http://www.pads.uwaterloo.ca/Bruno.Preiss/books/opus5/programs/pgm14_06.txt // public class DepthFirstBranchAndBoundSolver extends AbstractSolver { protected void search (Solution solution) { if (solution.isComplete ()) updateBest (solution); else { Enumeration i = solution.getSuccessors (); while (i.hasMoreElements ()) { Solution successor = (Solution) i.nextElement (); if (successor.isFeasible () && successor.getBound () < bestObjective) search (successor); } } } }