Warning: foreach() argument must be of type array|object, bool given in /var/www/html/web/app/themes/studypress-core-theme/template-parts/header/mobile-offcanvas.php on line 20

Suppose that each person in a group of \(n\) people votes for exactly two people from a slate of candidates to fill two positions on a committee. The top two finishers both win positions as long as each receives more than \(n/2\)votes.

a) Devise a divide-and-conquer algorithm that determines whether the two candidates who received the most votes each received at least \(n/2\)votes and, if so, determine who these two candidates are.

b) Use the master theorem to give a big- \(O\) estimate for the number of comparisons needed by the algorithm you devised in part (a).

Short Answer

Expert verified

(a)\(f(n) = 2f(n/2) + 12n\)

(b) \(O(n\log n)\)

Step by step solution

Achieve better grades quicker with Premium

  • Unlimited AI interaction
  • Study offline
  • Say goodbye to ads
  • Export flashcards

Over 22 million students worldwide already upgrade their learning with Vaia!

01

Recurrence Relation and Master Theorem definition

A recurrence relation is an equation that recursively defines a sequence where the next term is a function of the previous terms:\({\rm{f(n) = a f(n / b) + c}}\)

In MASTER THEOREM, let\(f\)be an increasing function that satisfies the recurrence relation\(f(n) = af(n/b) + c{n^d}\)whenever\(n = {b^k}\), where\(k\)is a positive integer,\(a \ge 1,b\)is an integer greater than\(1\), and\(c\)and\(d\)are real numbers with\(c\)positive and\(d\)nonnegative. Then\(f(n)\)is\(O\left( {{n^d}} \right)\)if\(a < {b^d}{\rm{ }}O\left( {{n^d}\log n} \right)\)if\(a = {b^d}\)and\(O\left( {{n^{{{\log }_b}a}}} \right)\)if\(a > {b^d}\).

02

Apply Recurrence Relation

(a)

When\(n = 1\)then the two people on the list are winners. If there are\(n\)voters, then we can assume that the list of all possible names contains\(2n\)names (each voter supplies two different names).

\(f(n)\)

We divide the list of\(2n\)names then into 2 lists of\(n\) names each. There can only be a majority for a candidate in the main list if both sub-lists also contain a major candidate.

Repeatedly divide the lists into two sub-lists (each) until we obtain sub-lists with at most 3 names (names that are repeated twice will then have a majority in the sublist).

When comparing the two lists of\({\bf{n}}\)names, then there are at most 3 names with a majority in each list. We need to compare the 3 names in one list with the 3 names in the other list as well as the frequency of occurrence of the names, which requires at most\(12n\)comparisons.

In total, we then note that the number of comparisons is twice the number of comparisons in a sublist of half-length increased by at most \(12n\) comparisons \(f(n) = 2f(n/2) + 12{n^3}\)

03

Apply Master Theorem 

(b)

When\(f(n) = af(n/b) + c{n^d}\)then:

\(f(n) = \left\{ {\begin{array}{*{20}{c}}{O\left( {{n^d}} \right),}&{{\rm{ if }}a < {b^d}}\\{O\left( {{n^d}\log n} \right),}&{{\rm{ if }}a = {b^d}}\\{O\left( {{n^{{{\log }_b}a}}} \right),}&{{\rm{ if }}a > {b^d}}\end{array}} \right.\)

\(a = 2\)

\(a = 2\)

\(c = 12\)

\(d = 1\)

In this case,\(a = 2 = {2^1} = {b^d}\):

\(O\left( {{n^d}\log n} \right) = O\left( {{n^1}\log n} \right) = O(n\log n)\)

Thus the worst-case time complexity of the algorithm min part (a) is\(O(n\log n)\).

One App. One Place for Learning.

All the tools & learning materials you need for study success - in one app.

Get started for free

Most popular questions from this chapter

See all solutions

Recommended explanations on Math Textbooks

View all explanations

What do you think about this solution?

We value your feedback to improve our textbook solutions.

Study anywhere. Anytime. Across all devices.

Sign-up for free