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

a) Describe in detail (and in English) the steps of an algorithm that finds the maximum and minimum of a sequence of elements by examining pairs of successive elements, keeping track of a temporary maximum and a temporary minimum. Ifn is odd, both the temporary maximum and temporary minimum should initially equal the first term, and ifn is even, the temporary minimum and temporary maximum should be found by comparing the initial two elements. The temporary maximum and temporary minimum should be updated by comparing them with the maximum and minimum of the pair of elements being examined.

b) Express the algorithm described in part (a) in pseudocode.

c) How many comparisons of elements of the sequence are carried out by this algorithm? (Do not count comparisons used to determine whether the end of the sequence has been reached.) How does this compare to the number of comparisons used by the algorithm in Exercise 5?

Short Answer

Expert verified

(a) The highest of the two consecutive values will be compared with the temporary

maximum “max “ and if is higher , then the value of the element is assigned to the

temporary maximum “max “.

The lowest of the two consecutive values will be compared with the temporary

minimum “min “ and if is lowest , then the value of the element is assigned to the

temporary minimum “min “.

(b) Procedure min and max (a1,a2,an:integerswithn1)

If n odd then

max:=a1

min:=a1

for i:=1 to (n-1)2

If a2i>a2i+1then

If a2i>maxthen max:=a2i

If a2i+1<min then min:=a2i+1

else

If a2i+1>max then max:=a2i+1

If a2i<minthen min:=a2i

If n even then

If a2>a1then

min:=a1

max:=a2

else

min:=a2

max:=a1

for i:=1 to (n-2)2

If a2i+2>a2i+1then

If a2i+2>maxthen max==a2i+2

If a2i+1<minthen min:=a2i+1

else

If a2i>maxthenmax:=a2i+1

Ifa2i+2<min then min:=a2i+2

returnmax, min

(c)n odd : 32(n-1)comparisons

neven: 32(n-2)+1comparisons

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

(a)Step 1: Steps for maximum and minimum algorithm

The input is a list of n elements.

If nodd, then we initial assign the temporary maximum ”max” and the temperature

minimum “ min “ as the first element .

Then the remaining number of elements is even and thus we can examine every

consecutive pair of two consecutive values.

The highest of the two consecutive values will be compared with the temporary

maximum “max “ and if is higher , then the value of the element is assigned to the

temporary maximum “max “.

The lowest of the two consecutive values will be compared with the temporary

minimum “min “ and if is lowest , then the value of the element is assigned to the

temporary minimum “min “.

If neven, then we initial assign the temporary maximum ”max” as the largest of the

First two elements and the temperature minimum “ min “ as the smallest of the first

element .

Then the remaining number of elements is even and thus we can examine every

consecutive pair of two consecutive values.

The highest of the two consecutive values will be compared with the temporary

maximum “max “ and if is higher , then the value of the element is assigned to the

temporary maximum “max “.

The lowest of the two consecutive values will be compared with the temporary

minimum “min “ and if is lowest , then the value of the element is assigned to the

temporary minimum “min “.

02

(b)Step 2: Algorithm in pseudocode

(a) Let us call the algorithm “min and max” and the input of the algorithm is a list of

Integersa1,a2,,an

Procedure min and max (a1,a2,an:integerswithn1)

First we will deal with the case that n is odd.

The variable “max” will keep track of the largest number and the variable “min”

will keep track of the smallest number.

If n odd then

max:=a1

min:=a1

Then the remaining number of elements is even and thus we can examine every

consecutive pair of two consecutive values.

The highest of the two consecutive values will be compared with the temporary

maximum “max “ and if is higher , then the value of the element is assigned to the

temporary maximum “max “.

The lowest of the two consecutive values will be compared with the temporary

minimum “min “ and if is lowest , then the value of the element is assigned to the

temporary minimum “min “.

fori:=1 ton-12

If a2i>a2i+1 thenrole="math" localid="1668494037548" max:=a2i

Ifa2i>max thenmax:=a2i

If a2i+1<min thenmin:=a2i+1

else

Ifa2i+1>max thenmax:=a2i+1

If a2I<min thenmin:=a2I

03

Algorithm in pseudocode

Next we will similarly deal with the case that n is even .

If n even then

If a2>a1then

min:=a1

max:=a2

else

min:=a2

max:=a1

for i:=1 to n-22

If a2i+2>a2i+1 then

If a2i+2>maxthenmax==a2I+2

If a2i+1<minthen min:=a2i+1

else

If a2i>maxthenmax:=a2i+1

If a2i+2<minthen min:=a2i+2

Finally we return the largest and smallest number.

returnmax, min

04

Algorithm in pseudocode

Combining these steps, we then obtain the algorithm:

Procedure min and max (a1,a2,an:integerswithn1)

If n odd then

max:=a1

min:=a1

for to n-12

If a2i>a2i+1 then i:=1

If then max:=a2i

If a2i+1<min then min:=a2i+1

else

If a2i+1>max then max:=a2i+1

If a2i<minthen min:=a2i

If n even then

If a2>a1 then

min:=a1

max:=a2

else

min:=a2

max:=a1

for i=1 to n-22

If a2i+2>a2i+1 then

If a2i+2>maxthen max==a2i+2

If a2i+1<min then min:=a2i+1

else

If a2i>maxthenmax:=a2i+1

If a2i+2<minthenmin:=a2i+2

returnmax, min

05

(c)Step 5: Number of comparisons

When n is odd, the algorithm makes 3 comparisons per iteration ( one in every

If-statement that is executed) of the for-loop.

Since i can take on values from 1 to n-12, there are n-12 iteration of the for-loop

And thus 3n-12comparisons are made.

When is even , the algorithm makes 3 comparisons per iteration ( one in every

If-statement that is executed) of the for-loop and 1 comparisons when initially

Assigning temporary minimum and temporary maximum.

Since i can take on values from 1 to n-22, there aren-22 iteration of the for-loop

And thus 3n-22+1 comparisons are made.

We note that the number of comparisons in this exercise is less than the number of

Comparisons 2(n - 1) in the previous exercise.

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