Bubble sort pseudocode: Bubblesort (A, n) // A is array, n items to sort For i = n-1 to 1 For j = 1 to i If A[j] < A[j+1] Swap (A[j], A[j+1]) (A) Determine the big-O running time (tight bound) of bubble sort in the left column. Show your derivation. This pseudocode assumes the array starts at index 1. Count comparisons as the critical operation. Your solution should count the exact number of comparisons as a function of n (number of items being sorted). In converting your formula for number of comparisons to a closed-form formula (as opposed to a summation formula), you do not need to show the derivation (such as writing the summation twice and dividing by two), though it is okay to do that. You do need to show the closed-form formula for exact number of comparisons, before simplifying it to a big-O representation. As a reference, study the stairs examples in the book. See figure 1.2, pg. 20.
Bubble sort pseudocode: Bubblesort (A, n)
// A is array, n items to sort
For i = n-1 to 1
For j = 1 to i If A[j] < A[j+1]
Swap (A[j], A[j+1])
(A) Determine the big-O running time (tight bound) of bubble sort in the left column. Show your derivation. This pseudocode assumes the array starts at index 1. Count comparisons as the critical operation. Your solution should count the exact number of comparisons as a function of n (number of items being sorted). In converting your formula for number of comparisons to a closed-form formula (as opposed to a summation formula), you do not need to show the derivation (such as writing the summation twice and dividing by two), though it is okay to do that. You do need to show the closed-form formula for exact number of comparisons, before simplifying it to a big-O representation.
As a reference, study the stairs examples in the book. See figure 1.2, pg. 20.
(B) Prove that f(n) = 1000n5 + 20000n2 + 32 is O(n6 ); Is this a tight upper bound? Why or why not?
data:image/s3,"s3://crabby-images/e73ba/e73ba34464d4f075681873385944f692e1376dae" alt="20 Chapter 1 / The Phases of Software Development
The value of twice the expression is n multiplied by n+ 1. We are now essen-
tially done. The number we computed is twice the quantity we want. So, to
obtain our simplified formula, we only need to divide by 2. The final simplifica-
tion is thus:
n(n + 1)
(1+2 + ... +n)
2
We will use this simplified formula to rewrite the Technique 2 time expres-
sion, but you'll also find that the formula occurs in many other situations. The
simplification for the Technique 2 expression is as follows:
Number of operations for Technique 2
=n+ 2(1 +2 +... +n)
= n+ 2 (n(n+ 1)) Plug in the formula for (1+2 +... +n)
— п+ n(n + 1)
Cancel the 2s
— п+ n +n
Multiply out
= n? + 2n
Combine terms
So, Technique 2 requires n? + 2n operations.
FIGURE 1.2 Deriving a Handy Formula
(1+2 +... +n) can be computed by first computing the sum of twice (1+2 +... +n), as
shown here:
1
+
+ ... + (n – 1) +
n
+ (n – 1) + ... +
(п +1) + (п+1) +
+
n
2
1
+ (п+1) + (п +1)
...
The sum is n(n + 1), so (1 +2 +... +n) is half this amount:
n(n+ 1)
(1 +2 +... +n)
2"
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 2 steps
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/60092/600925f3c879aa48326d2697cc12cbd501c16012" alt="Database System Concepts"
data:image/s3,"s3://crabby-images/b5b1d/b5b1d5cf4b4f0b9fa5f7299e517dda8c78973ae2" alt="Starting Out with Python (4th Edition)"
data:image/s3,"s3://crabby-images/861e9/861e9f01dc31d6a60742dd6c59ed7da7e28cd75d" alt="Digital Fundamentals (11th Edition)"
data:image/s3,"s3://crabby-images/134f1/134f1b748b071d72903e45f776c363a56b72169f" alt="C How to Program (8th Edition)"
data:image/s3,"s3://crabby-images/3a774/3a774d976e0979e81f9a09e78124a494a1b36d93" alt="Database Systems: Design, Implementation, & Manag…"
data:image/s3,"s3://crabby-images/307b2/307b272f255471d7f7dc31378bac8a580ae1c49c" alt="Programmable Logic Controllers"