preface
This is the 7th day of my participation in the August More Text Challenge.
Several common sorting algorithms.
Self-study, for reference only.
Bubble sort
Algorithm steps
-
Compare adjacent elements. If the first one is bigger than the second, swap them both.
-
Do the same for each pair of adjacent elements, starting from the first pair to the last pair at the end. When we do that, the last element is going to be the largest number.
-
Repeat this step for all elements except the last one.
-
Keep repeating the above steps for fewer and fewer elements at a time until there are no more pairs to compare.
Code implementation
Var arr =,1,6,9,3,2,8,7 [4]; Function compare(a, b) {if(a < b) return false else return true; } function exchange(arr, a, Var temp = arr[a] arr[a] = arr[b] arr[b] = temp} function bubbleSort(arr) {var I = 0; i < arr.length; i++) { for(var j = 0; j < arr.length - 1 - i; J ++){//j takes the last j+1 and it doesn't exist. If (compare(arr[j], arr[j + 1])) {exchange(arr, j, j + 1)}}}} sort(arr) console.log(arr) //[1, 2, 3, 4, 6, 7, 8, 9]Copy the code
Selection sort
Algorithm steps
-
First find the smallest (large) element in the unsorted sequence and store it at the beginning of the sorted sequence.
-
Find the smallest (largest) element from the remaining unsorted elements and place it at the end of the sorted sequence.
-
Repeat the second step until all elements are sorted.
Code implementation
Var arr = [4,1,6,9,3,2,8,7] Var temp = arr[a] arr[a] = arr[b] arr[b] = temp} function selectSort(arr) {let len = arr.length // Save array length for (let I = 0; i < len - 1; I ++) {let minIndex = I // let j = I + 1; j < len; J ++){if(arr[j] < arr[minIndex]) {if(arr[j] < arr[minIndex])}} if(I! == minIndex) { exchange(arr, i, minIndex) } } return arr } console.log(selectSort(arr)); //[1, 2, 3, 4, 6, 7, 8, 9]Copy the code
Insertion sort
It’s like playing poker
Algorithm steps
-
Treat the first element of the first to be sorted sequence as an ordered sequence and the second element to the last element as an unsorted sequence.
-
Scan the unordered sequence from beginning to end, inserting each scanned element into the appropriate place in the ordered sequence. (If the element to be inserted is equal to an element in the ordered sequence, the element to be inserted is inserted after the equal element.)
Code implementation
Var arr = [4,1,6,9,3,2,8,7] function insertSort(arr) {for(var I = 1; i < arr.length; I ++) {// Let curValue = arr[I]; // save the current element (value). While (j >= 0 && curValue < arr[j]) {// if (j >= 0 && curValue < arr[j]) {// if (arr[j + 1] = arr[j]; // Move all preceding elements that are larger than the current element by one j--; } arr[j + 1] = curValue; } return arr} console.log(insertSort(arr)) //[1, 2, 3, 4, 6, 7, 8, 9]Copy the code
Quick sort
Algorithm steps
-
Pick an element from the sequence, called pivot;
-
Reorder the array so that all elements smaller than the base value are placed in front of the base value and all elements larger than the base value are placed behind the base value (the same number can go to either side). After the partition exits, the benchmark is in the middle of the array. This is called a partition operation;
-
Recursively sorts subsequences of elements less than the base value and subsequences of elements greater than the base value;
To sum up, take an element as leader and iterate over the number array. Those smaller than leader are put into one array, and those larger than leader are put into another array.
Code implementation
Var arr =,6,1,9,3,2,8,7 [4]; function quickSort(arr) { if(arr == null || arr.length === 0) return []; var leader = arr[0]; var left = [], right = []; for(var i = 0; i < arr.length; i++) { if(arr[i] < leader) left.push(arr[i]); else right.push(arr[i]) } left = quickSort(left); right = quickSort(right); return left.concat(leader,right) } console.log(quickSort(arr)) //[1, 2, 3, 4, 6, 7, 8, 9]Copy the code
Merge sort
Algorithm steps
-
Apply for a space equal to the sum of two sorted sequences, which is used to store the combined sequence;
-
Set two Pointers, starting at the start of two sorted sequences;
-
Compare the elements pointed to by the two Pointers, select the smaller element into the merge space, and move the pointer to the next position;
-
Repeat step 3 until a pointer reaches the end of the sequence;
-
Copies all remaining elements of the other sequence directly to the end of the merged sequence.
Code implementation
Var arr =,6,1,9,3,2,8,7 [4]; Function mergeSort(arr) {let len = arr.length if(len < 2) return arr let middle = math. floor(len / 2) // Middle let left = Arr. slice(0, middle) // Split into two arrays let right = arr.slice(middle) return merge(mergeSort(left), mergeSort(right)) } function merge(left, right) { let result = [] while(left.length && right.length) { if(left[0] < right[0]) { result.push(left.shift()) } else { result.push(right.shift()) } } while(left.length) result.push(left.shift()) while(right.length) result.push(right.shift()) return result } console.log(mergeSort(arr));Copy the code
reference
Novice tutorial