Home > Web Front-end > JS Tutorial > JavaScript program to sort a linked list of 0, 1 and 2

JavaScript program to sort a linked list of 0, 1 and 2

WBOY
Release: 2023-09-08 21:05:05
forward
825 people have browsed it

用于对 0、1 和 2 的链接列表进行排序的 JavaScript 程序

In this tutorial, we will learn a JavaScript program to sort a linked list of 0, 1 and 2. Sorting algorithms are essential for any programming language, and JavaScript is no exception. Sorting a linked list of 0s, 1s, and 2s is a common problem developers face in coding interviews and real-world applications.

So, let’s dive into how to sort a linked list of 0, 1, and 2 using JavaScript programming.

What is sorting?

Sort is the process of arranging elements in a specific order (ascending or descending). It is a fundamental operation in computer science and has numerous applications in real-world scenarios. Sorting algorithms are used to organize data for efficient searches, reduce redundancy, and optimize space and time complexity.

Here are some examples of sorting in JavaScript:

Example 1 - Sort an array of numbers in ascending order:

Input: ar[]= [5, 3, 8, 1, 2, 9]
Output: [1, 2, 3, 5, 8, 9]
Copy after login

Example 2 - Sort an array of strings alphabetically:

Input: ['apple', 'banana', 'orange', 'grape']
Output: ['apple', 'banana', 'grape', 'orange']
Copy after login

What is a linked list?

A linked list is a linear data structure consisting of nodes linked together by pointers. Each node contains a data element and a reference to the next node in the list. Linked lists are often used in dynamic data structures where the size of the data changes frequently.

Problem Statement

The goal is to arrange and display the linked list consisting of 0, 1 and 2 in order. Let us understand it with an example:

Example

Input: 1 -> 1 -> 2 -> 0 -> 2 -> 0 -> 1 -> NULL 
Output: 0 -> 0 -> 1 -> 1 -> 1 -> 2 -> 2 -> NULL
Input: 1 -> 1 -> 2 -> 1 -> 0 -> NULL 
Output: 0 -> 1 -> 1 -> 1 -> 2 -> NULL 
Copy after login

Algorithm for sorting the linked list of 0, 1 and 2

Steps to sort linked list of 0, 1 and 2 using counting sort algorithm -

Step 1 - Define a function sortList(head) that takes as input the head of the linked list.

STEP2 - Initialize a count array count[] of size 3, with all elements equal to 0.

STEP 3 - Traverse the linked list and increment the count of the node data at the corresponding index in the array.

STEP 4 - Traverse the linked list again and replace the node data with the lowest index value with a count greater than 0.

Step 5 - Reduce the node data count for each replacement.

Step 6 - Print the linked list before and after sorting.

Now let us try to understand the above algorithm with an example of implementing it using JavaScript.

Example

The following JavaScript program sorts a linked list containing 0, 1, and 2 using the counting sort algorithm. The algorithm first counts the frequency of occurrence of 0, 1, and 2 in the list, and then updates the value of the node in the list based on the count of each value.

/* Link list node */
class Node {
   constructor(data) {
      this.data = data;
      this.next = null;
   }
}
class LinkedList {
   constructor() {
      this.head = null;
   }
   push(new_data) {
      const new_node = new Node(new_data);
      new_node.next = this.head;
      this.head = new_node;
   }
   printList() {
      let currentNode = this.head;
      let value = "";
      while (currentNode !== null) {
         value += currentNode.data + " -> ";
         currentNode = currentNode.next;
      }
      console.log(value + "null");
   }
   sortList() {
      const count = [0, 0, 0]; // Initialize count of '0', '1' and '2' as 0
      let ptr = this.head;
      while (ptr !== null) {
         count[ptr.data] += 1;
         ptr = ptr.next;
      }
      ptr = this.head;
      let i = 0;
      while (ptr !== null) {
         if (count[i] === 0) {
            ++i;
         } else {
            ptr.data = i;
            --count[i];
            ptr = ptr.next;
         }
      }
   }
}
const linkedList = new LinkedList();
linkedList.push(0);
linkedList.push(1);
linkedList.push(0);
linkedList.push(2);
linkedList.push(1);
linkedList.push(1);
linkedList.push(2);
linkedList.push(1);
linkedList.push(2);
console.log("Before sorting:");
linkedList.printList();
linkedList.sortList();
console.log("After sorting:");
linkedList.printList();
Copy after login

in conclusion

Overall, the above Javascript program demonstrates an efficient way to sort a linked list containing only 0, 1, and 2 using counting techniques. The algorithm has a time complexity of O(n) and a space complexity of O(1), making it the optimal solution for this particular sorting problem.

The above is the detailed content of JavaScript program to sort a linked list of 0, 1 and 2. For more information, please follow other related articles on the PHP Chinese website!

source:tutorialspoint.com
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template