Sorting is a very classic problem of reordering items that can be compared, e. There are many different sorting algorithms, each has its own advantages and limitations. Sorting is commonly used as the introductory problem in various Computer Science classes to showcase a range of algorithmic ideas. Without loss of generality, we assume that we will sort only Integers, not necessarily distinct, in non-decreasing order in this visualization. Try clicking Bubble Sort for a sample animation of sorting the list of 5 jumbled integers with duplicate above. Remarks: By default, we show e-Lecture Mode for first time or non logged-in visitor. Please if you are a repeated visitor or for an optional free account first. Discussion: In real-life classes, the instructor may elaborate more on these applications. Another pro-tip: We designed this visualization and this e-Lecture mode to look good on 1366x768 resolution or larger typical modern laptop resolution in 2017. We recommend using Google Chrome to access VisuAlgo. Go to full screen mode F11 to enjoy this setup. However, you can use zoom-in Ctrl + or zoom-out Ctrl - to calibrate this. In Exploration mode, you can experiment with various sorting algorithms provided in this visualization to figure out their best and worst case inputs. Remember that you can switch active algorithm by clicking the on the top side of this visualization page. Some sorting algorithms have certain additional options. For example, in Bubble Sort and Merge Sortthere is an option to also compute the inversion index of the input array this is an. At the top, you will see the list of commonly taught sorting algorithms in Computer Science classes. To facilitate more diversity, we randomize the active algorithm upon each page load. The first six merge sort vs quick sort are comparison-based sorting algorithms while the last two are not. We will discuss this idea this e-Lecture. The middle three algorithms are recursive sorting algorithms while the rest are usually implemented iteratively. They are called comparison-based as they compare pairs of elements of merge sort vs quick sort array and decide whether to swap them or not. These three sorting algorithms are the easiest to implement but also not the most efficient, as they run in O N 2. You should see a 'bubble-like' animation if you imagine the larger items 'bubble up' actually 'float to the right side of the array'. Comparison and swap require time that is bounded by a constant, let's call it c. There are two nested loops in the standard Bubble Sort. The outer loop runs for exactly N iterations. Even if our computer is super fast and can compute 10 8 operations in 1 second, Bubble Sort will need about 100 seconds to complete. However, it can be terminated early, e. The improvement idea is simple: If we go through the inner loop with no swapping at all, it means that the array is already sorted and we can stop Bubble Sort at that point. Without loss of generality, we can also implement Selection Sort in reverse: Find the position of the largest item Y and swap it with the last item. Insertion sort is similar to how most people arrange a hand of poker cards. These sorting algorithms are usually implemented recursively, use Divide and Conquer problem solving paradigm, and run in O N log N time for Merge Sort and O N log N time in expectation for Randomized Quick Sort. This is just the general idea and we need a few more details before we can discuss the true form of Merge Sort. We will dissect this Merge Sort algorithm by first discussing its most important sub-routine: The O N merge. This is achieved by simply comparing the front of the two arrays and take the smaller of the two at all times. However, this simple but fast O N merge sub-routine will need additional array to do this merging correctly. Concentrate on the last merge of the Merge Sort algorithm. Merge Sort is a Divide and Conquer sorting algorithm. The divide step is simple: Divide the current array into two halves perfectly equal if N is even or one side is slightly greater by one element if N is odd and then recursively sort the two halves. The conquer step is the one that does the most work: Merge the two sorted halves to form a sorted array, using the merge sub-routine. There will be at most k-1 comparisons. There are k moves from original array a to temporary array b and another k moves back. The important question is how many times this merge sub-routine is called. We will see that this is an optimal comparison-based sorting algorithm, i. The most important good part of Merge Sort is its O N log N performance guarantee, regardless of the original ordering of the input. That's it, there is no adversary test case that can make Merge Sort runs longer than O N log N for any array of N elements. Merge Sort is therefore very suitable to sort extremely large number of inputs as O N log N grows much slower than the O N 2 sorting algorithms that we have. Merge Sort is also a algorithm. There are however, several not-so-good parts of Merge Sort. First, it is actually not easy to implement from scratch. Second, it requires additional O N storage duringthus not really memory efficient and. Btw, if you are interested to see what have been done to address these classic Merge Sort not-so-good parts, you can read. Quick Sort is another Divide and Conquer sorting algorithm the other one discussed in this visualization page is. We will see that this deterministic, non randomized version of Quick Sort can have bad time complexity of O N 2 on adversary input before continuing with the and usable version later. Then, recursively sort the two parts. Conquer step: Don't be surprised. We will dissect this Quick Sort algorithm by first discussing its most important sub-routine: The O N partition classic version. Initially, both S1 and S2 regions are empty, i. These two cases are elaborated in the next two slides. First, we analyze the cost of one call of partition. Inside partition a, i, jthere is only a single for-loop that iterates through j-i times. As j can be as big as N-1 and i can be as low as 0, then the time complexity of merge sort vs quick sort is O N. Similar tothe time complexity of Quick Sort is then dependent on the number of times partition a, i, j is called. On such worst case input scenario, this is what happens: The first partition takes O N time, splits a into 0, 1, N-1 items, then recurse right. The second one takes O N-1 time, splits a into 0, 1, N-2 items, then recurse right again. Until the last, N-th partition splits a into 0, 1, 1 item, and Quick Sort recursion stops. This is the classic N+ N-1 + N-2 +. The best case scenario of Quick Sort occurs when partition always splits the array into two equal halves, like. When that happens, the depth of recursion is only O log N. As each level takes O N comparisons, the time complexity is O N log N. In practice, this is rare, thus we need to devise a better way:. Try Random Quick Sort on this large and somewhat random example array. Mini exercise: Implement the idea above to the implementation shown in. It will take about 1 hour lecture to properly explain why this randomized version of Quick Sort has expected time complexity of O N log N on any input array of N elements. In this e-Lecture, we will assume that it is true. If you need non formal explanation: Just imagine that on randomized version of Quick Sort that randomizes the pivot selection, we will not always get extremely bad split of 0 empty1 pivotand N-1 other items. This combination of lucky half-pivot-halfsomewhat lucky, somewhat unlucky, and extremely unlucky empty, pivot, the rest yields an average time complexity of O N log N. There is actually a way to make the randomized version of Quick Sort as currently merge sort vs quick sort in this VisuAlgo page still runs in O N 2. It is known also not proven in this visualization as it will take another 1 hour lecture to do so that all comparison-based sorting algorithms have a lower bound time complexity of Ω N log N. Thus, any comparison-based sorting algorithm with worst-case complexity O N log Nlike is considered an optimal algorithm, i. However, we can achieve faster sorting algorithm — i. Assumption: If the items to be sorted are Integers with small range, we can count the frequency of occurrence of each Integer in that small range and then loop through that small range to output the items in sorted order. The time complexity of Counting Sort is thus O N+kwhich is O N if k is small. We will not be able to do the counting part of Counting Sort merge sort vs quick sort k is relatively big due to memory limitation, as we need to store frequencies of those k integers. Assumption: If the items to be sorted are Integers with large range but of few digits, we can combine idea with Radix Sort to achieve the linear time complexity. In Radix Sort, we treat each item to be sorted as a string of w digits we pad Integers that have less than w digits with leading zeroes if necessary. Then we re-concatenate the groups again for subsequent iteration. Try Radix Sort on the example array above for clearer explanation. Notice that we only perform O w × N+k iterations. There are a few other properties that can be used to differentiate sorting algorithms on top of whether they are comparison or non-comparison, recursive or iterative. In this section, we will talk about in-place versus not in-place, stable versus not stable, and caching performance of sorting algorithms. A sorting algorithm is said to be an in-place sorting algorithm if it requires only a constant amount i. O 1 of extra space during the sorting process. Discussion: How about Bubble Sort, Selection Sort, Insertion Sort, Quick Sort randomized or notCounting Sort, and Radix Sort. A sorting algorithm is called stable if the relative order of elements with the same key value is preserved by the algorithm after sorting is performed. Example application of stable sort: Assume that we have student names that have been sorted in alphabetical order. Now, if this list is sorted again by tutorial group number recall that one tutorial group usually has many studentsa stable sort algorithm would ensure that all students in the same tutorial group still appear in alphabetical order of their names. merge sort vs quick sort Discussion: Which of the sorting algorithms discussed in this e-Lecture are stable. Actually, the C++ source code for many of these basic sorting algorithms are already scattered throughout these e-Lecture slides. For other programming languages, you can translate the given C++ source code to the other programming language. Usually, sorting is just a small part in problem solving process and nowadays, most of programming languages have their own sorting functions so we don't really have to re-code them unless absolutely necessary. In Python, you can use. In Java, you can use. If the comparison function is problem-specific, we may need to supply additional comparison function to those built-in sorting routines. Now that you have reached the end of this e-Lecture, do you think sorting problem is just as simple as calling built-in sort routine. Try these online judge problems to find out more:or This is not the end of the topic of sorting. When you explore other topics in VisuAlgo, you will realise that sorting is a pre-processing step for many other advanced algorithms for harder problems, e. VisuAlgo was conceptualised in 2011 by Dr Steven Halim as a tool to help his students better understand data structures and algorithms, by allowing them to learn the basics on their own and at their own pace. VisuAlgo contains many advanced algorithms that are discussed in Dr Steven Halim's book 'Competitive Programming', co-authored with his brother Dr Felix Halim and beyond. VisuAlgo is not designed to work well on small touch screens e. The minimum screen resolution for a respectable user experience is 1024x768 and only the landing page is relatively mobile-friendly. VisuAlgo is an ongoing project and more complex visualisations are still being developed. The most exciting development is the automated question generator and verifier the online quiz system that allows students to test their knowledge of basic data structures and algorithms. The questions are randomly generated via some rules and students' answers are instantly and automatically graded upon submission to our grading server. The training mode currently contains questions for 12 visualization modules. We will soon add the remaining 8 visualization modules so that every visualization module in VisuAlgo have online quiz component. Another active branch of development is the internationalization sub-project of VisuAlgo. This is a big task and requires crowdsourcing. Once the system is ready, we will invite VisuAlgo visitors to contribute, especially if you are not a native English speaker. Currently, we have also written public notes about VisuAlgo in various languages:,. VisuAlgo is free of charge for Computer Science community on earth. Using the offline copy of client-side VisuAlgo for your personal usage is fine. Note that VisuAlgo's online quiz component is by nature has heavy server-side component and there is no easy way to save the server-side scripts and databases locally. Currently, the general public can only use the 'training mode' to access these online quiz system. You can click to read our 2012 paper about this system it was not yet called VisuAlgo back in 2012. This work is done mostly by my past students. The most recent final reports are here:. Bug Reports or Request for New Features VisuAlgo is not a finished project. Dr Steven Halim is still actively improving VisuAlgo. His contact is the concatenation of his name and add gmail dot com.