国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Table of Contents
Linked list structure
Example
Solution to the problem
Rotate the linked list one by one
Time and space complexity
Rotate the linked list once
in conclusion
Home Web Front-end JS Tutorial JavaScript program to rotate linked list clockwise

JavaScript program to rotate linked list clockwise

Aug 25, 2023 am 11:37 AM

JavaScript program to rotate linked list clockwise

The basic structure of a linked list in JavaScript can be created using classes in JavaScript, and nodes can then be moved from one position to another for rotation. In this article, we will learn how to rotate a linked list clockwise in JavaScript programming language. We'll see code for a deeper understanding of these concepts.

In the given problem, we are given a linked list and we have to rotate it in a clockwise manner. This means, we have to put the last element first in every move, if we have to rotate k times, then we have to put the last element before the head or starting node of the linked list. To create the linked list we saw earlier, we need a class to bind data and a pointer to the next element.

Linked list structure

Example

First, we will create a class node that stores the value of the current node and a pointer to the next node. After that, we will create a push function to help create the linked list, and finally, we will create a display function to help print the linked list. Let's look at the code first -

// creating the class for the linked list
class Node{
   // defining the constructor for class
   constructor(){
      this.next = null; // pointer to hold the next value 
      this.value = 0; // curent value in the linked list 
   }
}
// defining push function for linked list 
function push(head,data){
   var new_node = new Node();
   new_node.value = data;
   if(head == null){
      return new_node;
   }
   var temp = head;
   while(temp.next != null){
      temp = temp.next;
   }
   temp.next = new_node;
   return head;
}
function display(head){
   var temp = head;
   var values = 0;
   while(temp){   
      values = values + temp.value + " -> ";
      temp = temp.next;
   }
   console.log(values + "null")
}
var head = null;
for(var i = 1;i<6;i++){
   head = push(head,i);
}
display(head)

In the above code, we have created a class using the class keyword and created a section using the "this" keyword to store the data and a pointer to the next node in the class constructor.

After that, we define a push function that will take two parameters, the first parameter is the head of the linked list, and the second parameter is the data of the new node we want to add to the linked list. In the function, we create the new node and store the value in it. We check if the head is empty (which means we will add the first element) and then we will simply return the new node, otherwise using a loop we will go to the end of the linked list and add the new node there.

Solution to the problem

After creating the class and defining the required basic functions, we will move to the main function where we will define the function that moves the last k elements to the front of the linked list, which represents the rotation of the linked list. There are two ways to add the last k elements to the first element, which is equivalent to a right rotation of the linked list, for example -

We are given a linked list: 1 -> 2 -> 3 -> 4 -> 5 ->null

We want to rotate the listed links once in a clockwise manner, so it looks like this -

5 -> 1 -> 2 -> 3 -> 4 -> null

Similarly, for 3 rotations of the linked list, the linked list will look like this -

Initially Linked list: 1 -> 2 -> 3 -> 4 -> 5 -> null
After the first rotation: 5 -> 1 -> 2 -> 3 -> 4 -> null
After the second rotation: 4 -> 5 -> 1 -> 2 -> 3 -> null
After the third rotation: 3 -> 4 -> 5 -> 1 -> 2 -> null

We have two ways to add the last element in front of the linked list, either one by one, or all at once.

Rotate the linked list one by one

Example

In this method we will go to the last node and then move it to the previous head node and update the head node. Let's take a look at the code first -

// creating the class for linked list
class Node{
   // defining the constructor for class
   constructor(){
      this.next = null; // pointer to hold the next value 
      this.value = 0; // curent value in the linked list 
   }
}
// defining push function for linked list 
function push(head,data){
   var new_node = new Node();
   new_node.value = data;
   if(head == null){
      return new_node;
   }
   var temp = head;
   while(temp.next != null){
      temp = temp.next;
   }
   temp.next = new_node;
   return head;
}

function display(head){
   var temp = head;
   var values = 0
   while(temp){
      values =  values + temp.value + " -> ";
      temp = temp.next;
   }
   console.log(values + "null")
}
function rotate(head, k){
   while(k--){
      var temp = head;
      while(temp.next.next != null){
         temp = temp.next;
      }
      var new_head = temp.next;
      temp.next = null;
      new_head.next = head;
      head = new_head;
   }
   return head;
}
var head = null;
for(var i = 1;i<6;i++){
   head = push(head,i);
}
head = rotate(head,3);
display(head);

In the above code, we use the basic function linked list code defined above and just add a new function to rotate the linked list.

In the function rotate, we first use a while loop to traverse the linked list k times, and in each iteration, we reach the penultimate element of the linked list. Then we remove the last element of the linked list from the linked list and place it in front of the head of the linked list. Finally, we return the new header and display the new linked list using the display function.

Time and space complexity

We have moved the linked list k times, and the size of the linked list is N, so the overall time complexity of the program is O(N*K). Additionally, we are not using any extra space, so the space complexity of the program is O(1), which is a constant.

Rotate the linked list once

In the previous code, we added the elements one by one, which took O(N*N) time, so that we can better move the linked list and get the size of the linked list. After that, we will traverse the linked list again and get the last k elements and add them to the front of the linked list, which will make the time complexity of the program O(1).

in conclusion

In this tutorial, we learned how to rotate a linked list clockwise in JavaScript programming language. We have seen the code to understand the concepts in depth. The basic structure of a linked list in JavaScript can be created using classes in JavaScript and then nodes can be moved from one position to another for rotation. The time complexity of the program is O(N*N), which can be further improved to O(N), while the space complexity of the program is O(1).

The above is the detailed content of JavaScript program to rotate linked list clockwise. For more information, please follow other related articles on the PHP Chinese website!

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

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Java vs. JavaScript: Clearing Up the Confusion Java vs. JavaScript: Clearing Up the Confusion Jun 20, 2025 am 12:27 AM

Java and JavaScript are different programming languages, each suitable for different application scenarios. Java is used for large enterprise and mobile application development, while JavaScript is mainly used for web page development.

Javascript Comments: short explanation Javascript Comments: short explanation Jun 19, 2025 am 12:40 AM

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

How to work with dates and times in js? How to work with dates and times in js? Jul 01, 2025 am 01:27 AM

The following points should be noted when processing dates and time in JavaScript: 1. There are many ways to create Date objects. It is recommended to use ISO format strings to ensure compatibility; 2. Get and set time information can be obtained and set methods, and note that the month starts from 0; 3. Manually formatting dates requires strings, and third-party libraries can also be used; 4. It is recommended to use libraries that support time zones, such as Luxon. Mastering these key points can effectively avoid common mistakes.

Why should you place  tags at the bottom of the ? Why should you place tags at the bottom of the ? Jul 02, 2025 am 01:22 AM

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavaScript vs. Java: A Comprehensive Comparison for Developers JavaScript vs. Java: A Comprehensive Comparison for Developers Jun 20, 2025 am 12:21 AM

JavaScriptispreferredforwebdevelopment,whileJavaisbetterforlarge-scalebackendsystemsandAndroidapps.1)JavaScriptexcelsincreatinginteractivewebexperienceswithitsdynamicnatureandDOMmanipulation.2)Javaoffersstrongtypingandobject-orientedfeatures,idealfor

JavaScript: Exploring Data Types for Efficient Coding JavaScript: Exploring Data Types for Efficient Coding Jun 20, 2025 am 12:46 AM

JavaScripthassevenfundamentaldatatypes:number,string,boolean,undefined,null,object,andsymbol.1)Numbersuseadouble-precisionformat,usefulforwidevaluerangesbutbecautiouswithfloating-pointarithmetic.2)Stringsareimmutable,useefficientconcatenationmethodsf

What is event bubbling and capturing in the DOM? What is event bubbling and capturing in the DOM? Jul 02, 2025 am 01:19 AM

Event capture and bubble are two stages of event propagation in DOM. Capture is from the top layer to the target element, and bubble is from the target element to the top layer. 1. Event capture is implemented by setting the useCapture parameter of addEventListener to true; 2. Event bubble is the default behavior, useCapture is set to false or omitted; 3. Event propagation can be used to prevent event propagation; 4. Event bubbling supports event delegation to improve dynamic content processing efficiency; 5. Capture can be used to intercept events in advance, such as logging or error processing. Understanding these two phases helps to accurately control the timing and how JavaScript responds to user operations.

What's the Difference Between Java and JavaScript? What's the Difference Between Java and JavaScript? Jun 17, 2025 am 09:17 AM

Java and JavaScript are different programming languages. 1.Java is a statically typed and compiled language, suitable for enterprise applications and large systems. 2. JavaScript is a dynamic type and interpreted language, mainly used for web interaction and front-end development.

See all articles