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

This exercise deals with the problem of finding the largest sum of consecutive terms of a sequence of\(n\)real numbers. When all terms are positive, the sum of all terms provides the answer, but the situation is more complicated when some terms are negative. For example, the maximum sum of consecutive terms of the sequence\( - 2,3, - 1,6, - 7,4\)is\(3 + ( - 1) + 6 = 8\). (This exercise is based on [Be\(86\)].) Recall that in Exercise\(56\)in Section\(8.1\)we developed a dynamic programming algorithm for solving this problem. Here, we first look at the brute-force algorithm for solving this problem; then we develop a divide-and-conquer algorithm for solving it.

a) Use pseudocode to describe an algorithm that solves this problem by finding the sums of consecutive terms starting with the first term, the sums of consecutive terms starting with the second term, and so on, keeping track of the maximum sum found so far as the algorithm proceeds.

b) Determine the computational complexity of the algorithm in part (a) in terms of the number of sums computed and the number of comparisons made.

c) Devise a divide-and-conquer algorithm to solve this problem. [Hint: Assume that there are even numbers of terms in the sequence and split the sequence into two halves. Explain how to handle the case when the maximum sum of consecutive terms includes terms in both halves.]

d) Use the algorithm from part (c) to find the maximum sum of consecutive terms of each of the sequences:\( - 2,4, - 1,3,5, - 6,1,2;4,1, - 3,7, - 1, - 5,3, - 2\); and\( - 1,6,\bar 3, - 4, - \bar 5,\bar 8, - 1,\bar 7\).

e) Find a recurrence relation for the number of sums and comparisons used by the divide-and-conquer algorithm from part (c).

f) Use the master theorem to estimate the computational complexity of the divide-and-conquer algorithm. How does it compare in terms of computational complexity with the algorithm from part (a)?

Short Answer

Expert verified
  1. The required result is to return to the max.
  2. The required result is,\((n - 1)n + (n - 1) = O\left( {{n^2}} \right)\).
  3. The required result is the maximum of the maximum sum of either sub-list or the maximum sum of a sequence of consecutive terms that contains elements from both sub-lists.
  4. The required result is max\((9,14,5 + 9) = 14\).
  5. The required result is\(T(n) = 2T(n/2) + n + 2\).
  6. The required result is\(O(n\log n)\)is better than the computational complexity \(O\left( {{n^2}} \right)\) of the algorithm in part (a).

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

Given expression

Step 1: Given expression

02

Formula of the sum of consecutive numbers and the Master theorem

Sum of\(n\)consecutive numbers\( = \frac{n}{2}{\rm{ (first number }} + {\rm{ last number) }}\)

The master theorem is a formula for solving recurrence relations of the form:\({\bf{T}}({\bf{n}}) = {\bf{aT}}({\bf{n}}/{\bf{b}}) + {\bf{f}}({\bf{n}})\), where\({\bf{n}} = \)the size of the input\({\bf{a}} = \)number of sub-problems is in the recursion\({\rm{n}}/{\rm{b}} = \)size of each subproblem. All subproblems are assumed to have the same size.

03

Find the sum of consecutive numbers

(a)

The algorithm "largest sum" and the input is a list of integers.

Procedure largest sum (\({a_1},{a_2}, \ldots ,{a_n}\) : integers with\(n \ge 1\))

The variable "max" will keep track of the largest sum.

Initially, define the maximum to be\(0\).

Max\( = 0\)

Then adjust the current maximum.

For \[i = 1\] to\(n\):

Sum\( = {a_i}\)

For\[j = i + 1\] to\[n\]:

Sum\[ = \]sum\[ + {a_j}\]

If, sum\[ > \]max, then max\[ = \]sum.

Finally, return to the max.

04

Find the computational complexity of the algorithm and the number of comparisons made

(b)

Calculate\(1\) sum (sum\[ = \]\[ + {a_j}\])and make\(1\)acomparison sum\[ > \]maxevery time that the inner for-loop is executed.

The inner for-loop is executed at most \(n - 1\) times for one value of \(i\) (since there are \(n - i\) values from \(i + 1\) to \(n\) and \(i\) is at least\(1\).

The outer for-loop is executed \({\bf{n}}\) times, because \(i\) from\(1\)to \({\bf{n}}\) contains \({\bf{n}}\) possible values for\(i\).

In total, the inner for-loop is then executed at most \((n - 1)n\) times.

The number of sums\( + \)Number of comparisons\( = (n - 1)n + (n - 1)\).

\(\begin{array}{l}(n - 1)n + (n - 1) = 2(n - 1)n\\(n - 1)n + (n - 1) = 2n - 2{n^2}\\(n - 1)n + (n - 1) = O\left( {{n^2}} \right)\end{array}\)

05

Explain how to handle the case when the maximum sum of consecutive terms includes terms in both halves

(c)

Base case:

When the list contains \(n = 1\) elements, then the maximum sum is the maximum of the element and\(0\).

Recursive case:

If the list contains\(2n\)elements, then divide the list into\(2\)sub-lists with \(n\) consecutive elements each.

Determine the maximum sum of each sub-list:

The maximum sum of the total list is then the maximum sum of either list or the maximum sum of a sequence of consecutive terms that contains elements from both sub-lists.

To determine the maximum sum of the sequence of the consecutive terms that contain terms from both sub-lists.

First, determine the maximum sum of the second list, where the sum needs to start from the first element in the second list.

Similarly, determine the maximum sum of the first list, where the sum needs to end with the last element in the first list.

Finally, the maximum sum of consecutive terms that contains terms from both sub-lists is then the sum of the two found maximums.

The result is then the maximum of the maximum sum of either sub-list or the maximum sum of a sequence of consecutive terms that contains elements from both sub-lists.

06

Compute the maximum sum \(C\) for the sub lists\(\{  - 2,4\} ,\{   - 1,3\} ,\{ 5, - 6\} ,\{ 1,2\} \)

(d)

First sequence:

\( - 2,4, - 1,3,5, - 6,1,2\)

Divide the list into sublists until it obtains sublists of\(1\)element each.

\(\begin{array}{l}\{ - 2,4, - 1,3\} ,\{ 5, - 6,1,2\} \\\{ - 2,4\} ,\{ - 1,3\} ,\{ 5, - 6\} ,\{ 1,2\} \\\{ - 2\} ,\{ 4\} ,\{ - 1\} ,\{ 3\} ,\{ 5\} ,\{ - 6\} ,\{ 1\} ,\{ 2\} \end{array}\)

When the list contains \(n = 1\) elements, then the maximum sum \(C\) is the maximum of the element and\(0\).

\(\begin{array}{c}C( - 2) = 0\\C(4) = 4\\C( - 1) = 0\\C(3) = 3\end{array}\)

\[\begin{array}{c}C(5) = 5\\C( - 6) = 0\\C(1) = 1\\C(2) = 2\end{array}\]

Next, compute the maximum sum \(C\) for the sub-lists\(\{ - 2,4\} ,\{ - 1,3\} ,\{ 5, - 6\} ,\{ 1,2\} \).

\(C( - 2,4) = \)Max\((C( - 2),C(4),C\)(elements of both lists)\()\)

\(C( - 2,4) = \)Max\((0,4, - 2 + 4)\)

\(C( - 2,4) = 4\)

Similarly,\(C( - 1,3) = 3,\,\,C(5, - 6) = 5,\,\,C(1,2) = 3\)

07

Step 6: Compute the maximum sum of the total list

Next, compute the maximum sum \(C\) for the sub lists \(\{ 4,1, - 3,7\} ,\{ - 1, - 5,3, - 2\} \)

\(C(4,1, - 3,7) = \)Max\((C(4,1),C( - 3,7),C\)(elements of both lists)\()\)

\(C(4,1, - 3,7) = \)Max\((5,7,9)\)\(4,1, - 3,7\)has a sum of\(9\)

\(C(4,1, - 3,7) = 9\)

Similarly,\(C( - 1, - 5,3, - 2) = 3\)\( - 5,3\)has the sum of\( - 2\).

Finally, compute the maximum sum of the total list.

\(C(4,1, - 3,7, - 1, - 5,3, - 2) = \)Max\((C(4,1, - 3,7),C( - 1, - 5,3, - 2),C\)(elements of both lists)\()\)

\(1, - 3,7\)has the sum of\(9\)in first sub-list\( - 1\)has the sum of\( - 1\)in second sub-list\( = \)max\((9,3,9 - 1)\).

Max\((9,3,9 - 1) = 9\).

08

compute the maximum sum\(C\)for the sub lists\(\{  - 1,6\} ,\{ 3, - 4\} ,\{  - 5,8\} ,\{   - 1,7\} \)

Third sequence:

\( - 1,6,3, - 4, - 5,8, - 1,7\)

Divide the list into sublists until it obtains sublists of\(1\)element each.

\(\begin{array}{l}\{ - 1,6,3, - 4\} ,\{ - 5,8, - 1,7\} \\\{ - 1,6\} ,\{ 3, - 4\} ,\{ - 5,8\} ,\{ - 1,7\} \\\{ - 1\} ,\{ 6\} ,\{ 3\} ,\{ - 4\} ,\{ - 5\} ,\{ 8\} ,\{ - 1\} ,\{ 7\} \end{array}\)

When the list contains\(n = 1\)elements, then the maximum sum\(C\)is the maximum of the element and\(0\).

\(\begin{array}{c}C( - 1) = 0\\C(6) = 6\\C(3) = 3\\C( - 4) = 0\end{array}\)

\(\begin{array}{c}C( - 5) = 0\\C(8) = 8\\C( - 1) = 0\\C(7) = 7\end{array}\)

Next, compute the maximum sum \(C\) for the sub-lists\(\{ - 1,6\} ,\{ 3, - 4\} ,\{ - 5,8\} ,\{ - 1,7\} \).

\(C( - 1,6) = \)Max\((C( - 1),C(6),C\)(elements of both lists)\()\)

\(C( - 1,6) = \)Max\((0,6, - 1 + 6)\)

\(C( - 1,6) = 6\)

Similarly,\(C(3, - 4) = 3,\,\,C( - 5,8) = 8,\,\,C( - 1,7) = 7\)

09

Step 8: Compute the maximum sum of the total list

Next, compute the maximum sum \(C\) for the sub-lists\(\{ - 1,6,3, - 4\} ,\{ - 5,8, - 1,7\} \).

\(\begin{array}{l}C( - 1,6,3, - 4) = 9\\C( - 5,8, - 1,7) = 14\end{array}\)

Finally, compute the maximum sum of the total list.

\(C( - 1,6,3, - 4, - 5,8, - 1,7) = \)Max\((C( - 1,6,3, - 4),C( - 5,8, - 1,7),C\)(elements of both lists)\()\).

\(6,3, - 4\)has the sum of\(5\)in first sub list\( - 5,8, - 1,7\)has the sum of\(9\)in second sub-list\( = \)max\((9,14,5 + 9)\).

Max\((9,14,5 + 9) = 14\).

10

Determine a recurrence relation for the number of sums

(e)

Let\(S\)represent the number of sums and\(T\)represent the number of comparisons. Initially, when\(n = 1\), calculate\(0\)sums and make one comparison (compare the element with\(0\)and the maximum is then the largest sum).

\(\begin{array}{l}S(1) = 0\\T(1) = 1\end{array}\)

\(S(n) = 2S(n/2) + \frac{n}{2} + \frac{n}{2} = 2S(n/2) + n\)

\(T(n) = 2T(n/2) + \frac{n}{2} + 1 + \frac{n}{2} + 1 = 2T(n/2) + n + 2\)

11

Step 10: Apply the Master theorem to find the computational complexity of the divide-and-conquer algorithm

(f)

Apply Master theorem:

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

Then,\(f(n) = \left\{ \begin{array}{l}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 }_0}a}}} \right),\,\,\,\,\,\,\,\,\,\,\,\,\,\,{\rm{if }}a > {b^d}\end{array} \right\}\)

\(a = 2\)

\(b = 2\)

\(c = 1\)

\(d = 1\)

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

\(\begin{array}{l}O\left( {{n^d}\log n} \right) = O\left( {{n^1}\log n} \right)\\O\left( {{n^d}\log n} \right) = O(n\log n)\end{array}\)

Note that \(O(n\log n)\)is better than the computational complexity \(O\left( {{n^2}} \right)\) of the algorithm in part (a).

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

Use generating functions to find an explicit formula for the Fibonacci numbers.

A sequence \({a_1},{a_2},.....,{a_n}\) is unimodal if and only if there is an index \(m,1 \le m \le n,\) such that \({a_i} < {a_i} + 1\) when \(1{1 < i < m}\) and \({a_i} > {a_{i + 1}}\) when \(m \le i < n\). That is, the terms of the sequence strictly increase until the \(m\)th term and they strictly decrease after it, which implies that \({a_m}\) is the largest term. In this exercise, \({a_m}\) will always denote the largest term of the unimodal sequence \({a_1},{a_2},.....,{a_n}\).

a) Show that \({a_m}\) is the unique term of the sequence that is greater than both the term immediately preceding it and the term immediately following it.

b) Show that if \({a_i} < {a_i} + 1\) where \(1 \le i < n\), then \(i + 1 \le m \le n\).

c) Show that if \({a_i} > {a_{i + 1}}\) where \(1 \le i < n\), then \(1 \le m \le i\).

d) Develop a divide-and-conquer algorithm for locating the index \(m\). (Hint: Suppose that \(i < m < j\). Use parts (a), (b), and (c) to determine whether \(((i + j)/2) + 1 \le m \le n,\) \(1 \le m \le ((i + j)/2) - 1,\) or \(m = ((i + j)/2)\)

Use generating functions (and a computer algebra package, if available) to find the number of ways to make change for $1 using

a) dimes and quarters.

b) nickels, dimes, and quarters.

c) pennies, dimes, and quarters.

d) pennies, nickels, dimes, and quarters.

Find the sequence with each of these functions as its exponential generating functionf(x)=e3x-3e2x.

To find number of edges and describe to make counting the edges easier.

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