Logo

dev-resources.site

for different kinds of informations.

Recap the highlight of the sorting algorithms using JavaScript for beginners

Published at
10/5/2024
Categories
sorting
algorithms
javascript
programming
Author
mshossain110
Author
12 person written this
mshossain110
open
Recap the highlight of the sorting algorithms using JavaScript for beginners

Sorting algorithms are methods used to arrange elements of a list or array in a specific order, typically numerical or lexicographical. They are fundamental in computer science for organizing data efficiently. It is an exercise in understanding how to break down a problem into steps and then implement those steps, i.e., how to create an algorithm. It's also an exercise in realizing that there are multiple methods to tackle an issue, and some are superior to others.

Why should I learn it?

  • It's a simple practical example for thinking recursively (see: merge sort and quick sort) and divide and conquer.
  • It's a simple but nontrivial example for algorithmic analysis (I.e. big O).
  • It's a traditional intro computer science topic that is expected to be taught.
  • It's a simple example to motivate why you might care about having a better algorithm than the simplest native one (I.e. bubble sort).

Here are some common sorting algorithms

Bubble Sort

Description: Repeatedly swaps adjacent elements if they are in the wrong order.
Time Complexity: O(n²)
Use Case: Simple but inefficient for large datasets.
Bubble Sort GitHub Gist

var arr = [10, 55, 20, 4, 28, 69, 22, 85, 7, 37];

function bubbleSort(arr)
{
    var temp, i, j;

    for(i = 0; i<arr.length; i++)
    {
        for(j = 0; j< arr.length; j++)
        {
            if (arr[j] > arr[j+1])
            {
                temp = arr[j];
                arr[j] = arr[j+1];
                arr[j+1] = temp;
            }
        }
    }

    return arr;
}

console.log(bubbleSort(arr));

Enter fullscreen mode Exit fullscreen mode

Selection Sort

Description: Selects the smallest element from the unsorted part and swaps it with the first unsorted element.
Time Complexity: O(n²)
Use Case: Inefficient for large datasets but easy to implement.
Selection Sort GitHub Gist

var arr = [10, 55, 20, 4, 28, 69, 22, 85, 7, 37];

function selectionSort(arr)
{
   var min;
   for(var i = 0; i < arr.length; i++)
   {
       min = i;
       for(var j = i+1; j < arr.length; j++ )
       {
           if (arr[j] < arr[min])
           {
               min = j;
           }
       }


       if (min !== i) {
           var s = arr[min];
           arr[min] = arr[i];
           arr[i] = s;
       }
   }

   return arr;
}

console.log(selectionSort(arr));
Enter fullscreen mode Exit fullscreen mode

Insertion Sort

Description: Builds the sorted list one element at a time by inserting each element into its correct position.
Time Complexity: O(n²)
Use Case: Good for small datasets or nearly sorted arrays.
Insertion Sort GitHub Gist

var arr = [10, 55, 20, 4, 28, 69, 22, 85, 7, 37];

function insertionSort(arr)
{
    for(let i = 1; i< arr.length; i++)
    {
        let key= arr[i];
        let j = i - 1

        while (j >= 0 && key < arr[j]) {
            arr[j+1] = arr[j];
            j--;
        }
        arr[j+1] = key;
    }

    return arr;
}

console.log(insertionSort(arr));
Enter fullscreen mode Exit fullscreen mode

Merge Sort

Description: Divides the array into halves, recursively sorts them, and then merges the sorted halves.
Time Complexity: O(n log n)
Use Case: Efficient for large datasets, uses additional space for merging.
Merge Sort GitHub Gist
Merge Sort 2 GitHub Gist

var unsortedArr = [10, 55, 20, 4, 28, 69, 22, 85, 7, 37];

function merge(left, right)
{
    const result = new Array();

    let i = j = 0;
    while (i < left.length && j < right.length) {
        if (left[i] < right[j]){
            result.push(left[i]);
            i++;
        }else {
            result.push(right[j]);
            j++;
        }
    }

    while (i < left.length) {
        result.push(left[i]);
        i++;
    }

    while (j < right.length) {
        result.push(right[j]);
        j++;
    }

    return result;
}

function mergeSort(arr)
{
    if (arr.length <= 1)
        return arr;

    const mid = Math.floor(arr.length/2);
    const LA = new Array();
    const RA = new Array();

    for(let i = 0; i< mid; i++)
        LA.push(arr[i]);

    for(let j = mid; j< arr.length; j++)
        RA.push(arr[j]);


    const leftSorted = mergeSort(LA);
    const rightSorted = mergeSort(RA);

    return merge(leftSorted, rightSorted);
}

console.log(mergeSort(unsortedArr));

Enter fullscreen mode Exit fullscreen mode

Quick Sort

Description: Selects a pivot element and partitions the array into two sub-arrays: elements less than the pivot and elements greater than the pivot, then recursively sorts the sub-arrays.
Time Complexity: O(n log n) on average, O(n²) in the worst case.
Use Case: Fast and widely used for large datasets.
Quick Sort GitHub Gist

var arr = [10, 55, 20, 4, 28, 69, 22, 85, 7, 37];

function partition(arr, low, high)
{
    const pivot = arr[high];

    let i = low -1;

    for(let j = low; j <= high -1; j++)
    {
        if (arr[j] < pivot) {
            i++
            swap(arr, i, j)
        }
    }

    swap(arr, i+ 1, high);

    return i + 1
}

function swap(arr, i, j)
{
    let temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
}

function QuickSort(arr, low, high)
{
    if (low  < high){
        const po = partition(arr, low, high);
        QuickSort(arr, low, po - 1);
        QuickSort(arr, po + 1, high);
    }

    return arr;
}

console.log(QuickSort(arr, 0, arr.length - 1));

Enter fullscreen mode Exit fullscreen mode

Heap Sort

Description: Converts the array into a heap data structure and repeatedly extracts the maximum element to build the sorted array.
Time Complexity: O(n log n)
Use Case: Efficient and doesn't require extra space like merge sort.

Radix Sort

Description: Non-comparative sorting algorithm that sorts elements digit by digit, starting from the least significant digit to the most significant.
Time Complexity: O(nk) where k is the number of digits.
Use Case: Suitable for sorting numbers or strings with fixed-length keys.

Bucket Sort

Description: Divides elements into several buckets and then sorts each bucket individually (usually using another sorting algorithm).
Time Complexity: O(n + k) where k is the number of buckets.
Use Case: Effective when input is uniformly distributed over a range.

Each algorithm has its strengths and weaknesses, and the choice of which one to use depends on the size of the dataset, memory constraints, and whether the data is partially sorted.

Let's discuss how often we should practice those.

sorting Article's
30 articles in total
Favicon
Difference Between Merge Sort and Quick Sort
Favicon
Leetcode 75. Sort Colors
Favicon
Sorted Data Structures in Python
Favicon
Sorting Algorithms That Use Hash Tables
Favicon
C# Essentials: Operator Overloading and Custom Sorting Made Simple
Favicon
Recap the highlight of the sorting algorithms using JavaScript for beginners
Favicon
Merge Sort Demystified: A Beginner's Guide to Divide and Conquer Sorting
Favicon
Understanding Bubble Sort: Simple Sorting Method
Favicon
Introduction to Sorting Algorithms in JavaScript
Favicon
Understanding the SQL ORDER BY Clause
Favicon
Demystifying Sorting Algorithms: Making Order Out of Chaos
Favicon
Merge Intervals : A unique Graph-based approach
Favicon
Bubble Sort
Favicon
COMPARATOR vs COMPARABLE - A Java Surprise You did in School!
Favicon
Streamlining Data Management with Python's sorted() Function
Favicon
1 billion rows challenge in MySQL
Favicon
1 billion rows challenge in PostgreSQL and ClickHouse
Favicon
Sorting in Java – how to, and how not to do it anymore
Favicon
Reversing sort order in Rust
Favicon
Priority Queue: Creating order from chaos
Favicon
Mastering Array Sorting in PHP: usort & uasort 🚀🚀
Favicon
QuickSort - Time Analysis (Part2)
Favicon
Quicksort (Grokking Algorithms)
Favicon
Better Bogo Sort
Favicon
Sorting Array of Objects in Javascript
Favicon
Bubble Sort
Favicon
Understanding insertion sort algorithm
Favicon
Sorting Visualizer [ A web app to visualize sorting algorithm ]
Favicon
How to sort complex objects with custom criteria in Python
Favicon
Iterative Sorting algorithms in Javascript

Featured ones: