70
1 UBE 602 Algorithm Complexity Theory Instructor: Kayhan Erciyes Lectures: W 13:30-16:15 Office Hours W 16:30-17.30 URL : http://www.ube.ege.edu.tr/~erciyes/ube602 Textbook: Algorithm Design by Jon Kleinberg and Eva Tardos . Addison Wesley, 2006. Reference : Michael Sipser , Intro. to the Theory of Computation , 2nd ed., Thompson Course Technology, 2005. Errata .

UBE 602

Embed Size (px)

DESCRIPTION

UBE 602. Algorithm Complexity Theory Instructor : Kayhan Erciyes Lectures: W 13:30-16:15 Office Hours W 16:30-17.30 URL : http://www.ube.ege.edu.tr/~erciyes/ube602 Textbook: Algorithm Design by Jon Kleinberg and Eva Tardos . Addison Wesley, 2006. - PowerPoint PPT Presentation

Citation preview

Page 1: UBE 602

1

UBE 602

Algorithm Complexity Theory

Instructor: Kayhan Erciyes

Lectures: W 13:30-16:15 Office Hours W 16:30-17.30 URL : http://www.ube.ege.edu.tr/~erciyes/ube602Textbook: Algorithm Design by Jon Kleinberg and Eva Tardos. Addison Wesley, 2006.Reference : Michael Sipser, Intro. to the Theory of Computation, 2nd ed., Thompson Course Technology, 2005. Errata.

Page 2: UBE 602

2

Topics

Part I : Design and Anaysis of Algorithms ( app. 7 weeks)

- Introduction : Some Representative Problems – Lec.1

- Basics of Algorithms Analysis : Computational Tractibility, Asymptotic Order of Growth Lec. 2, Lec.3

- Graphs : Graph Connectivity and Graph Traversal, Biparttiteness, Topological Ordering Lec. 4-Lec.6

- Greedy Algorithms : Interval Scheduling, MST, Kruskals Algorithm,

Clustering Lec. 7-Lec.9

- Divide and Conquer Algorithms : The Mergesort Algorithm, Recurrences, Counting Inversions, Finding the Closest Pair

of Points, Integer Multiplication Lec. 10-Lec.12

Page 3: UBE 602

3

Topics

- Dynamic Programming : Weighted Interval Scheduling: A Recursive Procedure, RNA Secondary Structure: Dynamic Programming Over Intervals, Sequence Alignment, Shortest Paths and Distance Vector Protocols Lec. 13- Lec.18

- Network Flow : Ford-Fulkerson Algorithm, Maximum Flows and Minimum Cuts in a Network, The Bipartite Matching Problem (Lec. 19-Lec.21)

Page 4: UBE 602

4

Topics

Part II : NP Completeness (app. 7 weeks)

- NP and Computational Intractability- PSPACE - Extending the Limits of Tractability : Finding Small Vertex

Covers, Solving NP-hard Problem on Trees, Coloring a Set of Circular Arcs, Constructing a Tree Decomposition of a Graph (Lec. 31-33)

- Approximation Algorithms : A Load Balancing Problem, The Center Selection Problem, Set Cover, the Pricing Method: Vertex Cover (Lec. 34-39)

- Randomized Algorithms : Finding the Global Minimum Cut, Random Variables and their Expectations, Randomized Divide-and-Conquer: Median-Finding and Quicksort, Hashing: A Randomized Implementation of Dictionaries, Finding the Closest Pair of Points: A Randomized Approach, Randomized Caching, Load Balancing, Packet Routing (Lec. 40-Lec.42)

Page 5: UBE 602

5

Grading

Programming and Written Assignments : 45 % Mid-term Exam : 15 % Presentation : 15 % (weeks 8-11)Final Exam : 25 %

Page 6: UBE 602

1.1 A First Problem: Stable Matching

Page 7: UBE 602

7

Matching Residents to Hospitals

Goal. Given a set of preferences among hospitals and medical school students, design a self-reinforcing admissions process.

Unstable pair: applicant x and hospital y are unstable if: x prefers y to its assigned hospital. y prefers x to one of its admitted students.

Stable assignment. Assignment with no unstable pairs. Natural and desirable condition. Individual self-interest will prevent any applicant/hospital deal

from being made.

Page 8: UBE 602

8

Stable Matching Problem

Goal. Given n men and n women, find a "suitable" matching. Participants rate members of opposite sex. Each man lists women in order of preference from best to

worst. Each woman lists men in order of preference from best to

worst.

Zeus Amy ClareBertha

Yancey Bertha ClareAmy

Xavier Amy ClareBertha

1st 2nd 3rd

Men’s Preference Profile

favorite least favorite

Clare Xavier ZeusYancey

Bertha Xavier ZeusYancey

Amy Yancey ZeusXavier

1st 2nd 3rd

Women’s Preference Profile

favorite least favorite

Page 9: UBE 602

9

Stable Matching Problem

Perfect matching: everyone is matched monogamously. Each man gets exactly one woman. Each woman gets exactly one man.

Stability: no incentive for some pair of participants to undermine assignment by joint action.

In matching M, an unmatched pair m-w is unstable if man m and woman w prefer each other to current partners.

Unstable pair m-w could each improve by eloping.

Stable matching: perfect matching with no unstable pairs.

Stable matching problem. Given the preference lists of n men and n women, find a stable matching if one exists.

Page 10: UBE 602

10

Stable Matching Problem

Q. Is assignment X-C, Y-B, Z-A stable?

Zeus Amy ClareBertha

Yancey Bertha ClareAmy

Xavier Amy ClareBertha

1st 2nd 3rd

Men’s Preference Profile

Clare Xavier ZeusYancey

Bertha Xavier ZeusYancey

Amy Yancey ZeusXavier

1st 2nd 3rd

Women’s Preference Profile

favorite least favorite favorite least favorite

Page 11: UBE 602

11

Stable Matching Problem

Q. Is assignment X-C, Y-B, Z-A stable?A. No. Bertha and Xavier will hook up.

Zeus Amy ClareBertha

Yancey Bertha ClareAmy

Xavier Amy ClareBertha

Clare Xavier ZeusYancey

Bertha Xavier ZeusYancey

Amy Yancey ZeusXavier

1st 2nd 3rd 1st 2nd 3rd

favorite least favorite favorite least favorite

Men’s Preference Profile Women’s Preference Profile

Page 12: UBE 602

12

Stable Matching Problem

Q. Is assignment X-A, Y-B, Z-C stable?A. Yes.

Zeus Amy ClareBertha

Yancey Bertha ClareAmy

Xavier Amy ClareBertha

Clare Xavier ZeusYancey

Bertha Xavier ZeusYancey

Amy Yancey ZeusXavier

1st 2nd 3rd 1st 2nd 3rd

favorite least favorite favorite least favorite

Men’s Preference Profile Women’s Preference Profile

Page 13: UBE 602

13

Stable Roommate Problem

Q. Do stable matchings always exist?A. Not obvious a priori.

Stable roommate problem. 2n people; each person ranks others from 1 to 2n-1. Assign roommate pairs so that no unstable pairs.

Observation. Stable matchings do not always exist for stable roommate problem.

B

Bob

Chris

Adam C

A

B

D

D

Doofus A B C

D

C

A

1st 2nd 3rd

A-B, C-D B-C unstableA-C, B-D A-B unstableA-D, B-C A-C unstable

is core of market nonempty?

Page 14: UBE 602

14

Propose-And-Reject Algorithm

Propose-and-reject algorithm. [Gale-Shapley 1962] Intuitive method that guarantees to find a stable matching.

Initialize each person to be free.

while (some man is free and hasn't proposed to every woman) {

Choose such a man m

w = 1st woman on m's list to whom m has not yet proposed

if (w is free)

assign m and w to be engaged

else if (w prefers m to her fiancé m')

assign m and w to be engaged, and m' to be free

else

w rejects m

}

Page 15: UBE 602

15

Proof of Correctness: Termination

Observation 1. Men propose to women in decreasing order of preference.

Observation 2. Once a woman is matched, she never becomes unmatched; she only "trades up."

Claim. Algorithm terminates after at most n2 iterations of while loop.Pf. Each time through the while loop a man proposes to a new woman. There are only n2 possible proposals. ▪

Wyatt

Victor

1st

A

B

2nd

C

D

3rd

C

B

AZeus

Yancey

Xavier C

D

A

B

B

A

D

C

4th

E

E

5th

A

D

E

E

D

C

B

E

Bertha

Amy

1st

W

X

2nd

Y

Z

3rd

Y

X

VErika

Diane

Clare Y

Z

V

W

W

V

Z

X

4th

V

W

5th

V

Z

X

Y

Y

X

W

Z

n(n-1) + 1 proposals required

Page 16: UBE 602

16

Proof of Correctness: Perfection

Claim. All men and women get matched.Pf. (by contradiction)

Suppose, for sake of contradiction, that Zeus is not matched upon termination of algorithm.

Then some woman, say Amy, is not matched upon termination. By Observation 2, Amy was never proposed to. But, Zeus proposes to everyone, since he ends up unmatched.

Page 17: UBE 602

17

Proof of Correctness: Stability

Claim. No unstable pairs.Pf. (by contradiction)

Suppose A-Z is an unstable pair: each prefers each other to partner in Gale-Shapley matching S*.

Case 1: Z never proposed to A. Z prefers his GS partner to A. A-Z is stable.

Case 2: Z proposed to A. A rejected Z (right away or later) A prefers her GS partner to Z. A-Z is stable.

In either case A-Z is stable, a contradiction. ▪

Bertha-Zeus

Amy-Yancey

S*

. . .

men propose in decreasingorder of preference

women only trade up

Page 18: UBE 602

18

Summary

Stable matching problem. Given n men and n women, and their preferences, find a stable matching if one exists.

Gale-Shapley algorithm. Guarantees to find a stable matching for any problem instance.

Q. How to implement GS algorithm efficiently?

Q. If there are multiple stable matchings, which one does GS find?

Page 19: UBE 602

19

Efficient Implementation

Efficient implementation. We describe O(n2) time implementation.

Representing men and women. Assume men are named 1, …, n. Assume women are named 1', …, n'.

Engagements. Maintain a list of free men, e.g., in a queue. Maintain two arrays wife[m], and husband[w].

– set entry to 0 if unmatched– if m matched to w then wife[m]=w and husband[w]=m

Men proposing. For each man, maintain a list of women, ordered by preference. Maintain an array count[m] that counts the number of proposals

made by man m.

Page 20: UBE 602

20

Efficient Implementation

Women rejecting/accepting. Does woman w prefer man m to man m'? For each woman, create inverse of preference list of men. Constant time access for each query after O(n) preprocessing.

for i = 1 to n inverse[pref[i]] = i

Pref

1st

8

2nd

7

3rd

3

4th

4

5th

1 5 26

6th 7th 8th

Inverse 4th 2nd8th 6th5th 7th 1st3rd

1 2 3 4 5 6 7 8

Amy

Amy

Amy prefers man 3 to 6since inverse[3] < inverse[6]

2 7

Page 21: UBE 602

21

Understanding the Solution

Q. For a given problem instance, there may be several stable matchings. Do all executions of Gale-Shapley yield the same stable matching? If so, which one?

An instance with two stable matchings. A-X, B-Y, C-Z. A-Y, B-X, C-Z.

Zeus

Yancey

Xavier

A

B

A

1st

B

A

B

2nd

C

C

C

3rd

Clare

Bertha

Amy

X

X

Y

1st

Y

Y

X

2nd

Z

Z

Z

3rd

Page 22: UBE 602

22

Understanding the Solution

Q. For a given problem instance, there may be several stable matchings. Do all executions of Gale-Shapley yield the same stable matching? If so, which one?

Def. Man m is a valid partner of woman w if there exists some stable matching in which they are matched.

Man-optimal assignment. Each man receives best valid partner.

Claim. All executions of GS yield man-optimal assignment, which is a stable matching!

No reason a priori to believe that man-optimal assignment is perfect, let alone stable.

Simultaneously best for each and every man.

Page 23: UBE 602

23

Man Optimality

Claim. GS matching S* is man-optimal.Pf. (by contradiction)

Suppose some man is paired with someone other than best partner. Men propose in decreasing order of preference some man is rejected by valid partner.

Let Y be first such man, and let A be first validwoman that rejects him.

Let S be a stable matching where A and Y are matched. When Y is rejected, A forms (or reaffirms)

engagement with a man, say Z, whom she prefers to Y. Let B be Z's partner in S. Z not rejected by any valid partner at the point when Y is

rejected by A. Thus, Z prefers A to B. But A prefers Z to Y. Thus A-Z is unstable in S. ▪

Bertha-Zeus

Amy-Yancey

S

. . .

since this is first rejectionby a valid partner

Page 24: UBE 602

24

Stable Matching Summary

Stable matching problem. Given preference profiles of n men and n women, find a stable matching.

Gale-Shapley algorithm. Finds a stable matching in O(n2) time.

Man-optimality. In version of GS where men propose, each man receives best valid partner.

Q. Does man-optimality come at the expense of the women?

no man and woman prefer to be witheach other than assigned partner

w is a valid partner of m if there exist somestable matching where m and w are paired

Page 25: UBE 602

25

Woman Pessimality

Woman-pessimal assignment. Each woman receives worst valid partner.

Claim. GS finds woman-pessimal stable matching S*.

Pf. Suppose A-Z matched in S*, but Z is not worst valid partner for

A. There exists stable matching S in which A is paired with a man,

say Y, whom she likes less than Z. Let B be Z's partner in S. Z prefers A to B. Thus, A-Z is an unstable in S. ▪

Bertha-Zeus

Amy-Yancey

S

. . .

man-optimality

Page 26: UBE 602

26

Extensions: Matching Residents to Hospitals

Ex: Men hospitals, Women med school residents.

Variant 1. Some participants declare others as unacceptable.

Variant 2. Unequal number of men and women.

Variant 3. Limited polygamy.

Def. Matching S unstable if there is a hospital h and resident r such that:

h and r are acceptable to each other; and either r is unmatched, or r prefers h to her assigned hospital; and either h does not have all its places filled, or h prefers r to at least

one of its assigned residents.

resident A unwilling towork in Cleveland

hospital X wants to hire 3 residents

Page 27: UBE 602

27

Application: Matching Residents to Hospitals

NRMP. (National Resident Matching Program) Original use just after WWII. Ides of March, 23,000+ residents.

Rural hospital dilemma. Certain hospitals (mainly in rural areas) were unpopular and

declared unacceptable by many residents. Rural hospitals were under-subscribed in NRMP matching. How can we find stable matching that benefits "rural

hospitals"?

Rural Hospital Theorem. Rural hospitals get exactly same residents in every stable matching!

predates computer usage

Page 28: UBE 602

28

Lessons Learned

Powerful ideas learned in course. Isolate underlying structure of problem. Create useful and efficient algorithms.

Potentially deep social ramifications. [legal disclaimer]

Page 29: UBE 602

1.2 Five Representative Problems

Page 30: UBE 602

30

Interval Scheduling

Input. Set of jobs with start times and finish times.Goal. Find maximum cardinality subset of mutually compatible jobs.

Time0 1 2 3 4 5 6 7 8 9 10 11

f

g

h

e

a

b

c

d

h

e

b

jobs don't overlap

Page 31: UBE 602

31

Weighted Interval Scheduling

Input. Set of jobs with start times, finish times, and weights.Goal. Find maximum weight subset of mutually compatible jobs.

Time0 1 2 3 4 5 6 7 8 9 10 11

20

11

16

13

23

12

20

26

Page 32: UBE 602

32

Bipartite Matching

Input. Bipartite graph.Goal. Find maximum cardinality matching.

C

1

5

2

A

E

3

B

D 4

Page 33: UBE 602

33

Independent Set

Input. Graph.Goal. Find maximum cardinality independent set.

6

2

5

1

7

3

4

6

5

1

4

subset of nodes such that no two joined by an edge

Page 34: UBE 602

34

Competitive Facility Location

Input. Graph with weight on each each node.Game. Two competing players alternate in selecting nodes. Not allowed to select a node if any of its neighbors have been selected.

Goal. Select a maximum weight subset of nodes.

10 1 5 15 5 1 5 1 15 10

Second player can guarantee 20, but not 25.

Page 35: UBE 602

35

Five Representative Problems

Variations on a theme: independent set.

Interval scheduling: n log n greedy algorithm.Weighted interval scheduling: n log n dynamic programming algorithm.Bipartite matching: nk max-flow based algorithm.Independent set: NP-complete.Competitive facility location: PSPACE-complete.

Page 36: UBE 602

Extra Slides

Page 37: UBE 602

37

Stable Matching Problem

Goal: Given n men and n women, find a "suitable" matching. Participants rate members of opposite sex. Each man lists women in order of preference from best to

worst. Each woman lists men in order of preference from best to

worst.

Zeus Bertha AmyDiane Erika Clare

Yancey Amy ClareDiane Bertha Erika

Xavier Bertha ClareErika Diane Amy

Wyatt Diane AmyBertha Clare Erika

Victor Bertha DianeAmy Erika Clare

1st 2nd 3rd 4th 5th

Men’s Preference List

favorite least favorite

Page 38: UBE 602

38

Stable Matching Problem

Goal: Given n men and n women, find a "suitable" matching. Participants rate members of opposite sex. Each man lists women in order of preference from best to

worst. Each woman lists men in order of preference from best to

worst.

Erika Yancey ZeusWyatt Xavier Victor

Diane Victor YanceyZeus Xavier Wyatt

Clare Wyatt YanceyXavier Zeus Victor

Bertha Xavier YanceyWyatt Victor Zeus

Amy Zeus WyattVictor Yancey Xavier

1st 2nd 3rd 4th 5th

Women’s Preference List

favorite least favorite

Page 39: UBE 602

39

Understanding the Solution

Claim. The man-optimal stable matching is weakly Pareto optimal.

Pf. Let A be last woman in some execution of GS algorithm to

receive a proposal. No man is rejected by A since algorithm terminates when last

woman receives first proposal. No man matched to A will be strictly better off than in man-

optimal stable matching. ▪

No other perfect matching (stable or unstable)where every man does strictly better

Page 40: UBE 602

40

Deceit: Machiavelli Meets Gale-Shapley

Q. Can there be an incentive to misrepresent your preference profile?

Assume you know men’s propose-and-reject algorithm will be run.

Assume that you know the preference profiles of all other participants.

Fact. No, for any man yes, for some women. No mechanism can guarantee a stable matching and be cheatproof.

A

X

X

Y

Y

Z

Z

Men’s Preference List

Women’s True Preference Profile

Zeus

Yancey

Xavier

1st

A

B

2nd

C

C

3rdClare

Bertha

Amy

1st 2nd 3rd

B

A

B

C

X

Y

Z

X

Z

Y

Y

Z

X

Amy Lies

Clare

Bertha

Amy

1st 2nd 3rd

X

Y

Z

Page 41: UBE 602

41

Lessons Learned

Powerful ideas learned in course. Isolate underlying structure of problem. Create useful and efficient algorithms.

Potentially deep social ramifications. [legal disclaimer] Historically, men propose to women. Why not vice

versa? Men: propose early and often. Men: be more honest. Women: ask out the guys. Theory can be socially enriching and fun! CS majors get the best partners!

Page 42: UBE 602

42

Victor proposes to Bertha.

Victor

Bertha

Page 43: UBE 602

43

Victor proposes to Bertha.

- Bertha accepts since previously unmatched.

Victor

Bertha

Page 44: UBE 602

44

Wyatt proposes to Diane.

Victor

Bertha

Diane

Wyatt

Page 45: UBE 602

45

Wyatt proposes to Diane.

- Diane accepts since previously unmatched.

Victor

Bertha

Diane

Wyatt

Page 46: UBE 602

46

Xavier proposes to Bertha.

Victor

Bertha

Diane

Wyatt

Bertha

Xavier

Page 47: UBE 602

47

Xavier proposes to Bertha.

- Bertha dumps Victor and accepts Xavier.

Victor

Bertha

Diane

Wyatt

Bertha

Xavier

Page 48: UBE 602

48

Diane

Wyatt

Bertha

Xavier

Victor proposes to Amy.

Amy

Victor

Victor

Bertha

Page 49: UBE 602

49

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Victor proposes to Amy.

- Amy accepts since previously unmatched.

Victor

Bertha

Page 50: UBE 602

50

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Yancey proposes to Amy.

Amy

Yancey

Victor

Bertha

Page 51: UBE 602

51

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Amy

Yancey

Yancey proposes to Amy.

- Amy rejects since she prefers Victor.

Victor

Bertha

Page 52: UBE 602

52

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Yancey proposes to Diane.

Diane

Yancey

Amy

Yancey

Victor

Bertha

Page 53: UBE 602

53

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Diane

Yancey

Yancey proposes to Diane.

- Diane dumps Wyatt and accepts Yancey.

Amy

Yancey

Victor

Bertha

Page 54: UBE 602

54

Bertha

Xavier

Amy

Victor

Diane

Yancey

Wyatt proposes to Bertha.

Bertha

Wyatt

Diane

Wyatt

Amy

Yancey

Victor

Bertha

Page 55: UBE 602

55

Victor

Bertha

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Wyatt proposes to Bertha.

- Bertha rejects since she prefers Xavier.

Page 56: UBE 602

56

Bertha

Xavier

Amy

Victor

Diane

Yancey

Wyatt proposes to Amy.

Amy

Wyatt

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Bertha

Wyatt

Page 57: UBE 602

57

Bertha

Xavier

Amy

Victor

Diane

Yancey

Wyatt proposes to Amy.

- Amy rejects since she prefers Victor.

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Bertha

Wyatt

Amy

Wyatt

Page 58: UBE 602

58

Victor

Bertha

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Wyatt proposes to Clare.

Clare

Wyatt

Page 59: UBE 602

59

Bertha

Xavier

Amy

Victor

Diane

Yancey

Clare

Wyatt

Wyatt proposes to Clare.

- Clare accepts since previously unmatched.

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Bertha

Wyatt

Amy

Wyatt

Page 60: UBE 602

60

Bertha

Xavier

Amy

Victor

Diane

Yancey

Clare

Wyatt

Zeus proposes to Bertha.

Bertha

ZeusVictor

Bertha

Diane

Wyatt

Amy

Yancey

Bertha

Wyatt

Amy

Wyatt

Page 61: UBE 602

61

Bertha

Xavier

Amy

Victor

Diane

Yancey

Clare

Wyatt

Zeus proposes to Bertha.

- Bertha rejects since she prefers Xavier.

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Bertha

Wyatt

Amy

Wyatt

Bertha

Page 62: UBE 602

62

Bertha

Xavier

Amy

Victor

Diane

Yancey

Clare

Wyatt

Zeus proposes to Diane.

Diane

Zeus

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Bertha

Wyatt

Amy

Wyatt

Bertha

Page 63: UBE 602

63

Victor

Bertha

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Clare

Wyatt

Bertha

Zeus

Diane

Zeus

Zeus proposes to Diane.

- Diane rejects Yancey and accepts Zeus.

Page 64: UBE 602

64

Bertha

Xavier

Amy

Victor

Clare

Wyatt

Diane

Zeus

Yancey proposes to Clare.

Clare

Yancey

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Bertha

Zeus

Page 65: UBE 602

65

Victor

Bertha

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Clare

Wyatt

Bertha

Zeus

Diane

Zeus

Clare

Yancey

Yancey proposes to Clare.

- Clare rejects since she prefers Wyatt.

Page 66: UBE 602

66

Bertha

Xavier

Amy

Victor

Clare

Wyatt

Diane

Zeus

Yancey proposes to Bertha.

Bertha

Yancey Victor

Bertha

Diane

Wyatt

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Bertha

Zeus

Clare

Yancey

Page 67: UBE 602

67

Victor

Bertha

Diane

Wyatt

Bertha

Xavier

Amy

Victor

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Clare

Wyatt

Bertha

Zeus

Diane

Zeus

Clare

Yancey

Bertha

Yancey

Yancey proposes to Bertha.

- Bertha rejects since she prefers Xavier.

Page 68: UBE 602

68

Bertha

Xavier

Amy

Victor

Clare

Wyatt

Diane

Zeus

Yancey proposes to Erika.

Erika

Yancey

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Bertha

Zeus

Clare

Yancey

Bertha

Yancey

Page 69: UBE 602

69

Bertha

Xavier

Amy

Victor

Clare

Wyatt

Diane

Zeus

Erika

Yancey

Yancey proposes to Erika.

- Erika accepts since previously unmatched.

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Bertha

Zeus

Clare

Yancey

Bertha

Yancey

Page 70: UBE 602

70

Bertha

Xavier

Amy

Victor

Clare

Wyatt

Diane

Zeus

Erika

Yancey

STOP

- Everyone matched. - Stable matching!

Victor

Bertha

Diane

Wyatt

Amy

Yancey

Diane

Yancey

Bertha

Wyatt

Amy

Wyatt

Bertha

Zeus

Clare

Yancey

Bertha

Yancey