Download presentation
Presentation is loading. Please wait.
Published byCecil Mosley Modified over 8 years ago
1
Greedy Algorithms
2
Surprisingly, many important and practical computational problems can be solved this way. Every two year old knows the greedy algorithm. In order to get what you want, just start grabbing what looks best.
3
Ingredients: Instances: The possible inputs to the problem. Solutions for Instance: Each instance has an exponentially large set of solutions. Cost of Solution: Each solution has an easy to compute cost or value. Specification Preconditions: The input is one instance. Postconditions: An valid solution with optimal cost. (minimum or maximum) Optimization Problems
4
with a Greedy Algorithm Instances: A set of objects and a relationship between them. Solutions for Instance: A subset of the objects. Or some other choice about each object. Some subsets are not allowed because some objects conflict
5
Optimization Problems with a Greedy Algorithm Instances: A set of objects and a relationship between them. Solutions for Instance: A subset of the objects. Or some other choice about each object. Cost of Solution: The number of objects in solution or the sum of the costs of objects
6
Optimization Problems with a Greedy Algorithm Instances: A set of objects and a relationship between them. Goal: Find an optimal non-conflicting solution.
7
The Brute Force Algorithm Exponential Time, because exponential many Try every solution!
8
The Greedy Choice Commit to the object that looks the ``best'' Must prove that this locally greedy choice does not have negative global consequences.
9
The Game Show Example Problem: Choose the best m prizes.
10
The Game Show Example Problem: Choose the best m prizes. Greedy: Start by grabbing the best. Consequences: If you take the lion, you cant take the elephant. But greedy algorithms do not try to predict the future and do not back track.
11
The Game Show Example Iterative Greedy Algorithm: Loop: grabbing the best, then second best,... if it conflicts with committed objects or fulfills no new requirements. Reject this next best object else Commit to it. Problem: Choose the best m prizes.
12
The Game Show Example Makes a greedy first choice and then recurses (See Recursive Backtracking Algorithms) Recursive Greedy Algorithm: Problem: Choose the best m prizes.
13
Making Change Example Problem: Find the minimum # of quarters, dimes, nickels, and pennies that total to a given amount.
14
Instances: A set of objects and a relationship between them. Some subsets are not allowed because some objects conflict 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ Solutions for Instance: A subset of the coins that total the amount. Making Change Example
15
Instances: A set of objects and a relationship between them. 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ Solutions for Instance: A subset of the coins that total the amount. Cost of Solution: The number of objects in solution or the sum of the costs of objects = 14 Making Change Example Goal: Find an optimal non-conflicting solution.
16
Instances: A set of objects and a relationship between them. 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ Making Change Example Greedy Choice: Does this lead to an optimal # of coins? Start by grabbing quarters until exceeds amount, then dimes, then nickels, then pennies. Cost of Solution: 7
17
Hard Making Change Example Greedy Choice: Start by grabbing a 4 coin. Problem: Find the minimum # of 4, 3, and 1 cent coins to make up 6 cents. Consequences: 4+1+1 = 6 mistake 3+3=6 better Greedy Algorithm does not work!
18
When Does It Work? Greedy Algorithms: Easy to understand and to code, but do they work? For most optimization problems, all greedy algorithms tried do not work. A few have greedy algorithm. The proof that they work, however, is subtle. As with all iterative algorithms, we use loop invariants.
19
Designing an Algorithm Define ProblemDefine Loop Invariants Define Measure of Progress Define StepDefine Exit ConditionMaintain Loop Inv Make ProgressInitial ConditionsEnding 79 km to school Exit 79 km75 km Exit 0 kmExit
20
The algorithm chooses the “best” object from amongst those not considered so far and either commits to it or rejects it. Define Step Another object considered Make Progress 79 km75 km Exit When all objects have been considered Exit Exit Condition
21
“The” optimal solution contains the best object: There may be more than one optimal solution and all might not contain the chosen object. At least one optimal solution contains the best object: It is ok to burn a few of your bridges as long as you do not burn all of them. We do not go “wrong” by committing to the best object. First Choice
22
We have not gone wrong. There is at least one optimal solution consistent with the choices made so far. Loop Invariant Initially no choices have been made and hence all optimal solutions are consistent with these choices. codeA Establishing Loop Invariant
23
¬ codeB Exit Maintaining Loop Invariant Let optS LI denote one. opt sol consistent with choices made. codeB Commits or rejects the next best object. Proof massages optS LI into optS ours and proves it is a valid solution is consistent both with previous and new choices. is optimal opt sol consistent with all choices. ?
24
Algorithm: commits or rejects next best object Emphasizes his actions not part of algorithm Emphasizes alg and prover do not know optS LI. Prover: Proves LI is maintained. Three Players Fairy God Mother: Holds the hypothetical opt sol optS LI. optS LI She gives no feedback.
25
Algorithm: commits or rejects next best object Emphasizes his actions not part of algorithm Prover: Proves LI is maintained. Three Players Fairy God Mother: Does she exist? optS LI The prover would find his conversations equally supportive, even if she did not.
26
Different 25 ¢ are considered to be different. Massaging optS LI into optS ours 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ I have committed to these coins. I instruct how to massage optS LI into optS ours so that it is consistent with previous & new choice. I commit to keeping another 25 ¢ I hold optS LI witnessing that there is an opt sol consistent with previous choices. I hold optS ours witnessing that there is an opt sol consistent with previous & new choices. optS LI
27
I know that her optS LI Is consistent with these choices. As Time Goes On 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ I keep making more choices. I always hold an opt sol optS LI but which one keeps changing. optS LI Hence, I know more and more of optS LI In the end, I know it all.
28
I will now instruct how to massage optS LI into optS ours so that it is consistent with previous & new choice. Massaging optS LI into optS ours 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ optS LI
29
If it happens to be the case that what you hold is consistent with this new choice that was made, then we are done. Massaging optS LI into optS ours 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ optS LI
30
The Algorithm has 92 ¢ -50 ¢ = 42 ¢ unchosen. Massaging optS LI into optS ours 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ optS LI Fairy God Mother must also have 25 ¢ that I don’t know about. There are different cases. 25 ¢
31
Massaging optS LI into optS ours optS LI 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ Replace A different 25 ¢ Alg’s 25 ¢ With
32
Massaging optS LI into optS ours optS LI 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ Replace A different 25 ¢ Alg’s 25 ¢ With 3 × 10 ¢ Alg’s 25 ¢ + 5 ¢ Oops, this is not actually optimal, But we must consider all cases.
33
Massaging optS LI into optS ours optS LI 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ Replace A different 25 ¢ Alg’s 25 ¢ With 3 × 10 ¢ 2 × 10 ¢ + 1 × 5 ¢ Alg’s 25 ¢ + 5 ¢ Alg’s 25 ¢
34
Massaging optS LI into optS ours optS LI 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ Replace A different 25 ¢ Alg’s 25 ¢ With 3 × 10 ¢ 2 × 10 ¢ + 1 × 5 ¢ Alg’s 25 ¢ + 5 ¢ 1 × 10 ¢ + 3 × 5 ¢ Alg’s 25 ¢
35
Massaging optS LI into optS ours optS LI 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ Replace A different 25 ¢ Alg’s 25 ¢ With ?? + 5 × 1 ¢ 3 × 10 ¢ 2 × 10 ¢ + 1 × 5 ¢ Alg’s 25 ¢ + 5 ¢ 1 × 10 ¢ + 3 × 5 ¢ Alg’s 25 ¢
36
optS LI Done optS ours Massaging optS LI into optS ours She now has something we must prove that it is what we want.
37
optS ours optS ours is valid optS LI was valid and we introduced no new conflicts. Massaging optS LI into optS ours Total remains unchanged. Replace A different 25 ¢ Alg’s 25 ¢ With ?? + 5 × 1 ¢ 3 × 10 ¢ 2 × 10 ¢ + 1 × 5 ¢ Alg’s 25 ¢ + 5 ¢ 1 × 10 ¢ + 3 × 5 ¢ Alg’s 25 ¢
38
optS ours is consistent Massaging optS LI into optS ours optS LI was consistent with previous choices and we made it consistent with new. 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ optS ours
39
optS ours is optimal We do not even know the cost of an optimal solution. Massaging optS LI into optS ours optS LI was optimal and optS ours cost (# of coins) is not bigger. Replace A different 25 ¢ Alg’s 25 ¢ With ?? + 5 × 1 ¢ 3 × 10 ¢ 2 × 10 ¢ + 1 × 5 ¢ Alg’s 25 ¢ + 5 ¢ 1 × 10 ¢ + 3 × 5 ¢ Alg’s 25 ¢ optS ours
40
optS ours is valid optS ours is consistent optS ours is optimal optS ours Massaging optS LI into optS ours Case 1 ¬ codeB Exit Maintaining Loop Invariant optS ours
41
optS LI I hold optS LI witnessing that there is an opt sol consistent with previous choices. I must make sure that what the Fairy God Mother has is consistent with this new choice. Massaging optS LI into optS ours Case 2 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ I reject the next 25 ¢
42
The Algorithm has 92 ¢ -75 ¢ = 17 ¢ 25 ¢ unchoosen. Massaging optS LI into optS ours 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ optS LI Fairy God Mother must also have 25 ¢ that I don’t know about. optS LI does not contain the 25 ¢ either.
43
Massaging optS LI into optS ours ¬ codeB Exit Maintaining Loop Invariant optS ours
44
I know that her optS LI Is consistent with these choices. As Time Goes On 25 ¢ 10 ¢ 5 ¢ 1 ¢ Amount = 92 ¢ I keep making more choices. I always hold an opt sol optS LI but which one keeps changing. optS LI Hence, I know more and more of optS LI In the end, I know it all
45
codeC Exit Clean up loose ends Alg commit to or reject each object. Has giving a solution S. opt sol consistent with these choices. S must be optimal. Alg returns S. codeC
46
Designing an Algorithm Define ProblemDefine Loop Invariants Define Measure of Progress Define StepDefine Exit ConditionMaintain Loop Inv Make ProgressInitial ConditionsEnding 79 km to school Exit 79 km75 km Exit 0 kmExit
47
Making Change Example Greedy Choice: Start by grabbing quarters until exceeds amount, then dimes, then nickels, then pennies. Problem: Find the minimum # of quarters, dimes, nickels, and pennies that total to a given amount. Does this lead to an optimal # of coins? Yes
48
Hard Making Change Example Greedy Choice: Start by grabbing a 4 coin. Problem: Find the minimum # of 4, 3, and 1 cent coins to make up 6 cents.
49
I will now instruct how to massage optS LI into optS ours so that it is consistent with previous & new choice. Massaging optS LI into optS ours 4¢4¢ 4¢4¢ 4¢4¢ 4¢4¢ 4¢4¢ 4¢4¢ 4¢4¢ 4¢4¢ 4¢4¢ 4¢4¢ 3 ¢ 1 ¢ Amount = 6 ¢ optS LI I commit to keeping a 4 ¢ I hold optS LI. Oops!
50
Hard Making Change Example Greedy Choice: Start by grabbing a 4 coin. Problem: Find the minimum # of 4, 3, and 1 cent coins to make up 6 cents. Consequences: 4+1+1 = 6 mistake 3+3=6 better Greedy Algorithm does not work!
51
Running Time Greedy algorithms are very fast because they take only a small amount of time per object in the instance.
52
Ingredients: Instances: Events with starting and finishing times,,…, >. Solutions: A set of events that do not overlap. Cost of Solution: The number of events scheduled. Goal: Given a set of events, schedule as many as possible. The Job/Event Scheduling Problem
53
Possible Criteria for Defining “Best” The Shortest Event Counter Example Does not book the room for a long period of time. Motivation: Optimal Schedule first Optimal Greedy Criteria:
54
Possible Criteria for Defining “Best” The Earliest Starting Time Counter Example Common scheduling algorithm. Motivation: Optimal Schedule first Optimal Greedy Criteria:
55
Possible Criteria for Defining “Best” Conflicting with the Fewest Other Events Counter Example So many can still be scheduled. Motivation: Schedule first Optimal Greedy Criteria:
56
Possible Criteria for Defining “Best” Earliest Finishing Time Schedule the event who will free up your room for someone else as soon as possible. Motivation: Works! Greedy Criteria:
57
The Greedy Algorithm
58
Designing an Algorithm Define ProblemDefine Loop Invariants Define Measure of Progress Define StepDefine Exit ConditionMaintain Loop Inv Make ProgressInitial ConditionsEnding 79 km to school Exit 79 km75 km Exit 0 kmExit
59
We have not gone wrong. There is at least one optimal solution consistent with the choices made so far. Loop Invariant Initially no choices have been made and hence all optimal solutions are consistent with these choices. codeA Establishing Loop Invariant
60
¬ codeB Exit Maintaining Loop Invariant Let optS LI denote one. opt sol consistent with choices made. codeB Commits or rejects the next best object. Proof massages optS LI into optS ours and proves it is a valid solution is consistent both with previous and new choices. is optimal opt sol consistent with these choices.
61
Massaging optS LI into optS ours optS LI I hold optS LI witnessing that there is an opt sol consistent with previous choices. I instruct how to massage optS LI into optS ours so that it is consistent with previous & new choice. I commit to keeping next event i. Case 1
62
Massaging optS LI into optS ours optS LI Start by adding new event i. Delete events conflicting with job i.
63
Massaging optS LI into optS ours optS LI optS LI was valid and we removed any new conflicts. optS ours is valid
64
Massaging optS LI into optS ours optS LI optS LI was consistent. We added event i. Events in Commit don’t conflict with event i and hence were not deleted. optS ours is consistent
65
Massaging optS LI into optS ours optS LI optS LI was optimal. If we delete at most one event then optS ours is optimal too. optS ours is optimal
66
Massaging optS LI into optS ours optS LI Only one in optS LI. Deleted at most one event j j i<j j runs at time f i. Two such j conflict with each other. j’ [j conflicts with i] s j f i f i f j
67
optS LI optS ours optS ours is valid optS ours is consistent optS ours is optimal optS ours Massaging optS LI into optS ours Case 1 ¬ codeB Exit Maintaining Loop Invariant
68
optS LI I hold optS LI witnessing that there is an opt sol consistent with previous choices. I reject next event i. Massaging optS LI into optS ours Case 2 Event i conflicts with committed to events so cant be in optS LI either.
69
optS LI Massaging optS LI into optS ours ¬ codeB Exit Maintaining Loop Invariant
70
codeC Exit Clean up loose ends Alg commit to or reject each event. Has a solution S. opt sol consistent with these choices. S must be optimal. Alg returns optS. codeC
71
Designing an Algorithm Define ProblemDefine Loop Invariants Define Measure of Progress Define StepDefine Exit ConditionMaintain Loop Inv Make ProgressInitial ConditionsEnding 79 km to school Exit 79 km75 km Exit 0 kmExit
72
Running Time Greedy algorithms are very fast because they take only a small amount of time per object in the instance. Checking whether next event i conflicts with previously committed events requires only comparing it with the last such event.
73
Fixed vs Adaptive Priority Fixed Priority: Sort the objects from best to worst and loop through them. Adaptive Priority: –Greedy criteria depends on which objects have been committed to so far. –At each step, the next “best’’ object is chosen according to the current greedy criteria. –Searching or re-sorting takes too much time. –Use a priority queue.
74
Fixed vs Adaptive Priority
75
Example Dijkstra's shortest weighted path algorithm can be considered to be a greedy algorithm with an adaptive priority criteria.
Similar presentations
© 2025 SlidePlayer.com Inc.
All rights reserved.