1 / 24

Algorithms: Design and Analysis

Learn about backtracking search, with examples of finding all subsets, permutations, and solving the 8-queens problem. Understand the concept of searching through a data structure and making choices about paths. Explore strategies to efficiently navigate vast search spaces and calculate space sizes. Discover how to construct all subsets and permutations using backtracking. Enhance problem-solving skills with practical implementations in Java.

ameliah
Download Presentation

Algorithms: Design and Analysis

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Algorithms: Design and Analysis 240-310, Semester2, 2018-2019 • Objectives • explain backtracking search, and give three examples (all subsets, permutations, and 8-queens) 2. Backtracking

  2. 1. Backtracking Features • Search down a data structure to the 'end' • e.g. search a binary tree • The search involves choices about which path to take • e.g. go to left or right child? • let's go left! • At 'end', go back to last choice point, and try a different choice. • e.g. go back to parent node, let's go right! • Stop when back at start, and no more choices.

  3. Search Space • The problem may have many answers, spread across a very large “search space” • Brute force strategy: look at all the answers in the search space to find the best one(s) • Today’s CPUs can handle search spaces containing billions of answers (about 109) • In some problems, we can stop as soon as one answer is found – fast but answer may not be the best

  4. Calculating the Search Space Size • Search space size is related to the number of variables in the problem, and their values • e.g., 20 variables, each one 0 or 1; there are 220 different solutions, or about 106 • e.g., 12 variables, each one 0, 1, 2, …, or 9; there are1012different solutions • e.g., 12 variables, holding the permutation of 1, 2, 3, …, 12; there are 12! = 479,001,600different solutions

  5. Backtracking Pseudo-code private static void search(Data[] vars, int k) { if (vars.length == k) // looked at all vars? reportSoln(vars); // returning after the report will continue the search else { // process kth var Data[] candidates = getCandidates(vars, k); for(Data c : candidates) { // for all values of kth var vars[k] = c; search(vars, k+1); } } } // end of search()

  6. Search Space as a Tree • E.g., vars = { v0, v1, v2 } can have values 0, 1, or 2 search one solution == one path v0 1 0 2 choice point v1 0 1 2 0 1 2 0 1 2 . . . . . . . . . . . . . . . v2 0 1 2 0 1 2 0 1 2 exit or use backtracking to try alternative paths

  7. 2. Constructing All Subsets • Given a set with n items, we have 2n subsets. How to output all the subsets? • E.g., the subsets of {1, 2, 3 } are { 1 2 3 } { 1 2 } { 1 3 } { 1 } { 2 3 } { 2 } { 3 } { } Use three variables, v0, v1, v2. Each of them can be either true or false. viis true means that i+1is in the subset.

  8. Search Space as a Tree Use three variables, v0, v1, v2. Each of them can be either true or false. viis true means that i+1is in the subset. search one possible solution v0 == {1,2,3} F T == {3} v1 T F F T T F T F v2 T F T F use backtracking to try alternative paths

  9. Constructing All Subsets see AllSubsets.java /* output all the subsets of {1, 2, 3} */ public static void main(String[] args) { boolean[] vars = new boolean[3]; search(vars, 0); } // end of main() > java AllSubsets { 1 2 3 } { 1 2 } { 1 3 } { 1 } { 2 3 } { 2 } { 3 } { } vars[0] represents "1", vars[1] represents 2", etc. vars[i] == true value means i+1 is in the set

  10. private static void search(boolean[] vars, int k) { if (vars.length == k) // looked at all vars? reportSoln(vars); else { // process kth var boolean[] candidates = getCandidates(vars, k); for (booleanc : candidates) { vars[k] = c; search(vars, k+1); } } } // end of search() Contest Algorithms: 4. Backtracking

  11. private static boolean[] getCandidates(boolean vars[], int k) { return new boolean[]{ true, false}; } private static void reportSoln(boolean vars[]) { System.out.print(" {"); for(int i = 0; i < vars.length; i++) { if (vars[i]) System.out.print(" " + (i+1)); } System.out.println(" }"); } // end of reportSoln() vars[0] represents "1", vars[1] represents 2", etc. vars[i] == true value means print i+1

  12. 3. Constructing All Permutations • Permutation of {0, 1, 2} are 012 021 102 120 201 210 Use three variables, v0, v1, v2. Each of them can be assigned 0, 1, or 2 But can only use 0, 1, or 2 once per path

  13. Search Space as a Tree Use three variables, v0, v1, v2. Each of them can be assigned 0, 1, or 2 But can only use 0, 1, or 2 once per path search one solution == one path v0 1 0 2 v1 0 1 0 2 1 2 v2 2 1 2 0 1 0 use backtracking to try alternative paths

  14. Constructing All Permutations see Permutations.java public static void main(String[] args) { int[] vars = {-1, -1, -1}; // -1 means 'no value' search(vars, 0); } // end of main() > java Permutations 0 1 2 0 2 1 1 0 2 1 2 0 2 0 1 2 1 0 vars[0] represents "0", vars[1] represents 1", etc.

  15. private static void search(int[] vars, int k) { if (vars.length == k) // looked at all vars? reportSoln(vars); else { // process kth var int[] candidates = getCandidates(vars, k); for (intc : candidates) { vars[k] = c; search(vars, k+1); } } } // end of search()

  16. private static boolean[] getCandidates(intvars[], int k) { boolean[] inPerms = new boolean[vars.length]; for(int i = 0; i < vars.length; i++) inPerms[i] = false; for(int i = 0; i < k; i++) if (vars[i] != -1) inPerms[vars[i]] = true; // using vars[i] int n = 0; int[] c = new int[vars.length - k]; for(int i = 0; i < vars.length; i++) if (!inPerms[i]) /* candidates must be */ c[n++] = i; /* different from existing */ /* elements */ return c; } // end of getCandidates()

  17. private static void reportSoln(boolean vars[]) { for(int v: vars) System.out.print(" " + v); System.out.println(); } // end of reportSoln() Contest Algorithms: 4. Backtracking

  18. 4. Eight-Queens Problem • Put 8 queens on an 8×8 chessboard such that none of them is able to affect any of the others. • A solution requires that no two queens share the same row, column, or diagonal. • How many solutions? (92)

  19. Eight-Queens Problem • If a queen can be placed at any square, the search space is 648. Maybe too large! (648 == 26*8 == 248 ≈ 1012 * 28 = 2.56 x1014) • Position constraintshelp to reduce the size of search space • The queen in the first column has 8 choices. • Next, the queen in the second column has 7 choices. • Next, the queen in the third column has 6 choices. Etc. • Using these constraints, the space size is 8! = 40320 only. • We can also add diagonal constraints to reduce the size more

  20. Search Space this path succeeds  this path fails     X X     X X X X    X X X X  

  21. Eight-Queens Problem see Queens8.java private static int solnsCount = 0; // there are 92 solutions public static void main(String[] args) { int[] qs = new int[8]; search(qs, 0); System.out.println("No. of solutions: " + solnsCount); } // end of main()

  22. private static void search(int[] qs, int k) { if (qs.length == k) // looked at all qs? reportSoln(qs); else { // process kth var for (int i = 0; i < qs.length; i++) { qs[k] = i; if (isConsistent(qs, k)) search(qs, k+1); } } } // end of search() replace getCandidates() by loop and isConsistent()

  23. : _ _ _ _ _ _ _ Q _ _ Q _ _ _ _ _ Q _ _ _ _ _ _ _ _ _ _ _ _ Q _ _ _ Q _ _ _ _ _ _ _ _ _ _ Q _ _ _ _ _ _ _ _ _ Q _ _ _ _ Q _ _ _ _ _ _ _ _ _ _ _ Q _ _ _ Q _ _ _ _ Q _ _ _ _ _ _ _ _ _ Q _ _ _ _ _ _ _ _ _ _ Q _ _ _ Q _ _ _ _ _ _ _ _ _ _ _ _ Q _ _ _ _ _ Q _ _ _ No. of solutions: 92 private static void reportSoln(int qs[]) { for (int i = 0; i < qs.length; i++) { for (int j = 0; j < qs.length; j++) { if (qs[i] == j) System.out.print("Q "); else System.out.print("_ "); } System.out.println(); } System.out.println(); solnsCount++; } // end of reportSoln()

  24. private static boolean isConsistent(int[] q, int k) /* Return true if queen placement qs[k] does not conflict with other queens qs[0] through qs[k-1] */ { for (int i = 0; i < k; i++) { if (q[i] == q[k]) // same row return false; if ((q[i] - q[k]) == (k - i)) // same major diagonal return false; if ((q[k] - q[i]) == (k - i)) // same minor diagonal return false; } return true; } // end of isConsistent() three position constraints

More Related