W01 Analyze: Performance
Overview
This assignment must be completed individually to ensure you are meeting all course outcomes. You should not complete this assignment with a group. If you obtain help from a tutor, the tutor should help you understand principles but should not help you answer these problems. It is an honor code violation to obtain answers for these problems from others including using the internet (i.e. sites that allow students to share their solutions).
Instructions
All of the coding files for this assignment will be found in the course week01/analyze
folder in the course repository.
This assignment will be submitted as a Canvas Quiz.
Part 1: Analyze Code
In this section, you will be asked several questions that need to be answered in your response document:
- Open the file
Sorting.cs
and determine the big O notation for theSortArray
function. - Open the file
StandardDeviation.cs
and determine the big O notation for the three implementations of calculating the standard deviation from a list of numbers. - There are several other common big O notations that occur in various algorithms including
- Merge Sort Algorithm - O(n log n) - Logarithmic Linear Time
- Traveling Salesman Algorithm - O(2 ^ n) - Exponential Time
- Using either a graphing calculator or a graphing website (e.g. desmos.com), put the following in order (best performance, …, worst performance) for when n is large:
- O(n^2), O(1), O(2^n), O(n log n), O(log n), O(n)
Part 2: Predicting, Measuring, and Comparing - Two Sorting Algorithms
- Open up the following code: Search.cs
- This file contains two different functions called
SearchSorted1
andSearchSorted2
. Both of these functions will search for an item in a sorted list. Predict the performance of each function using big O notation and provide your answer in the response document. - Run the code and observe the outputs. Here is what the columns in the table represent:
n
- The size of the data given to the functions in this testsort1-count
- The number of loop iterations (i.e. work) done by SearchSorted1sort2-count
- The number of loop iterations (i.e. work) done by SearchSorted2sort1-time
- The time in milliseconds it took to complete SearchSorted1sort2-time
- The time in milliseconds it took to complete SearchSorted2
- While the
sort#-count
value should be the same in every execution, thesort#-time
will vary every time it is executed on the same or different computers. For the timing numbers, the code ran the test one hundred times and took the average. This was done since there are some operating system conditions that could affect timing in some cases. To ensure worst case, each test tried to find a number that was not in the list. - Answer the following questions:
- What is the performance using big O notation for each function (based on both your predictions and the actual results)?
- Which function has the better performance in the worst case?
Submission
- Return to Canvas to submit your responses in the associated quiz.