“This is the third day of my participation in the Gwen Challenge in November. Check out the details: The last Gwen Challenge in 2021.”
Js does not have a built-in linked list, so we usually create this data structure first
How does Baidu explain linked lists
Let’s draw a picture
Each node is structured as a simple property val and next val is the information field and next is the pointer field (the reference address in JS)
This structure allows us to operate nicely on the head node
As shown in the figure, each node next points to the next node and the last node is null if it does not point to it
Create a ListNode
class ListNode {
constructor(val, next) {
this.val = val
this.next = next || null}}Copy the code
Generate a linked list
So here we’re doing an array to a list, so we just have to declare an array
// Array list
function genereteList (arr) {
// Enter a header
const head = new ListNode()
let cur = head
for (let i = 0; i < arr.length; i++) {
cur.next = {
val: arr[i],
next: null
}
// Point to the next node the next node to build the node
cur = cur.next
}
return head.next
}
Copy the code
What about lists to arrays? How to deal with
functon generateArray(list) {
var cur = list
var arr = []
while(cur) {
arr.push(cur.val)
cur = cur.next
}
return arr
}
Copy the code
So we can get our linked list by creating an array scroll down
var arr = [1.2.3]
var list = generateList(arr)
// list: {val: 1, next: {val: 2, next: {val: 3, next: null}}}
Copy the code
So let’s do the linked list gradually
Merges two ascending lists
Merges two ascending lists into a new ascending list and returns. A new list is formed by concatenating all the nodes of a given two lists
For example, 1=>2=>3 2=>3=>4 And then 1=>2=>2=>3=>3=>4
The arrows in the figure compare the size of the two sizes in turn to form a new linked list according to the path shown in the figure
- Both lists are in ascending order, so we can compare them one by one and save the smaller nodes
- After 1 node is sorted, we need to arrange 2=>3 and 2=>3=>4, then 3 and 2=>3=>4, and then we need to arrange the second list after the first list is sorted, and then we need to put the rest of the second list behind it
function mergeSortList(l1, l2) {
// Create a storage node
var head = new ListNode()
// In the second part above we need a node to correspond to the point after each comparison
var cur = head
// We stop the loop when we cur to null (l1 or L2)
while(l1 ! = =null&& l2 ! = =null) {
if (l1.val > l2.val) {
cur.next = l1
l1 = l1.next
} else {
cur.next = l2
l2 = l2.next
}
}
cur.next = l1 === null ? l2 : l1
return head.next
}
Copy the code
So, we did it in a loop, but what about recursion?
- Define a recursive function: compare the size of the current val of l1 and L2, and compare the size of the current val of next with another
- Boundary condition: when L1 or L2 is null
function reverseList(l) {
if (l1 === null) {
return l1
} else if (l2 === null) {
return l2
} else if (l1.val < l2.val) {
l1.next = reverseList(l1.next, l2)
return l1
} else {
l2.next = revserseList(l2.next, l1)
return l2
}
}
Copy the code
conclusion
- The structure of linked lists
- Conversion between arrays and linked lists
- Loop over: changing the direction of an intermediate variable through an intermediate variable
- Merges two ascending linked lists
- Change the node pointer by comparing the size
- Linked list pointer pointing to changes in thinking