This is an old revision of the document!


2.3 Implementing The Stable Matching Algorithm using Lists and Arrays

To asymptotically analyze the running time of an algorithm, we don't need to implement and run it, but we definitely have to think about how the data will be represented and manipulated in an implementation of the algorithm so we could bound the number of computational steps it takes. This section looks at how to implement the Gale-Shapley algorithm using lists and arrays. In the Stable Matching Problems that the algorithm solves, we need to think about how the rankings will be represented, as each man and each woman has a ranking of all members of the opposite gender. In addition, we will need to know which men and women are free, and who is matched with whom. Finally, we need to decide which data structures to use for all of the mentioned data. The goal of for the designer is to choose data structures that will make the algorithm efficient and easy to implement.

Algorithm Analysis

Let's focus on a single list, such as a list of women in order of preference by a single man.

  • The simplest way to keep a list of n elements is to use an Array A of length n.
  • In such an array, let A[i] be the ith element of the list
  • With such an array we can:
  • Determine the ithelement on the list in O(1) time,by accessing the value A[i]
  • Determine if a given element e belongs to the list by checking the elements one by one in O(n) time, assuming we don't know the order in which the elements are arranged in A.
  • Determine if the given element e belongs to A in O(logn) if A is sorted
courses/cs211/winter2012/journals/jeanpaul/chaptter2section3.1327357056.txt.gz · Last modified: 2012/01/23 22:17 by mugabej
CC Attribution-Noncommercial-Share Alike 4.0 International
Driven by DokuWiki Recent changes RSS feed Valid CSS Valid XHTML 1.0