Tag: Solved

This problem has been solved

25 Posts

What does it mean for a sorting algorithm to be stable? Why? Is Selection Sort stable?
Answer:   A sorting algorithm is considered stable if it preserves the relative order of items with equal values. This means that if two elements in the list are equal, their order relative to each other remains the same after sorting.   For. e.g. in a list of tuples[(Earl,80), (Sebastian, 80),(David,90), (Charlie,70)]  is going to be sorted by the grades of students. Two people in the grades have the same grade 80 - Sebastian and Earl. Earl is at index 0 while Sebastian is at index v3 in the unsorted list - Earl has a lower Index than Sebastian. If the list is sorted by a stable sorting algorithm, to maintain the relative order of all items, Earl would have a lower index than Sebastian in the sorted list. The expected sorted list under a stable sorting algorithm would be:       [(Charlie,70), (Earl,80), (Sebastian, 80),(David,90)], (UPDATED EXAMPLE)   However, in selection sort, as non-adjacent elements are swapped, the relative order of all items in the output may be disrupted. As such, the expected output…
Explain why the best and worst case in selection sort are as stated. No explanation no marks.
Answer: Regardless of whether or not a list is sorted, the amount of times we iterate through the list is the same as the selection sort algorithm does not know if all the elements have been sorted without checking. It will still go through itself to find the smallest element and swap it with itself. The algorithm hence takes O(N^2) comparisons, so it has an O(N) complexity.Feedback: Last sentence O(N^2) not O(N)
Explain what one iteration in selection sorting does.
Answer: For each iteration of Selection Sort we find the minimum value starting at the 0th index and traverse the list. We store the minimum value in a variable and note the index it was found. We then place the current value of the array at the current index in a temp variable. We replace the current value with the minimum and the value at which minimum value was found with the temp variables value.
The main idea of Selection Sort
Answer: Selection Sort finds the minimum value for each index of the array and successively does this until the end of the array is reached.    To add on: Once it “selects” the minimum value in the unsorted portion of the list it then swaps it into the end of the sorted portion of the list, which will be its final position.  
What does it mean for a sorting algorithm to be stable? Why? Is Bubble Sort stable?
Answer: A sorting algorithm is said to  be stable if the relative order is maintained after the list has been sorted. For example: [1,3a,3b,2]->[1,2,3a,3b] this is stable.  Bubble sort is stable because of the strict < comparison in the code (elements are only swapped if they are less than the other element, so equal elements are not swapped and the relative order is maintained). Using <= would make it unstable.      Feedback:  The ‘>’ comparison is being done, elements are swapped if the element on the left is greater than the one on the right.
What does it mean for a sorting algorithm to be incremental? Is BubbleSort incremental? Why and when?
Answer: An algorithm is said to be incremental if it does not need to recompute everything after a small change. For example: adding an element to a sorted list and sorting it again. If it only takes a few iterations, it would be called incremental.  Bubble sort is incremental when the element is added to the front of the list because it will reach its correct position in the list in the first iteration. But if you add it to the end of the list, the number of iterations required would depend on the position of the element. (Include an example) Adding onto this ^^:  This is because of the invariant that mentions that in each traversal, the largest unsorted element will get to its final position.     Eg:  Original sorted list: [3, 6, 10, 14, 18, 20]  After appending 13 at the end: [3, 6, 10, 14, 18, 20, 13] Note that 14, 18 and 20 are not in their final positions and require 3 traversals of the list in order to sort the list. …
When does Bubble Sort stop? Describe at least one way to improve Bubble Sort.
Answer: Bubble sort 1 stops after n-1 iterations of the outer loop. Bubble sort 2 stops when none of the elements have been swapped in the last. Bubble sort 2 is the optimised version of bubble sort 1 where there is a conditional break if the list becomes sorted before n-1 traversals are over.   Feedback: Missing word have been swapped in the previous iteration.   …where n is the number of elements in the list