DEV Community

Cover image for Data Structure (Types of Linked List)
Nihal Islam
Nihal Islam

Posted on

Data Structure (Types of Linked List)

There are different types of linked lists. Basically they are all similar with few details changed so that we can use them regarding our needs. In this section we are gonna learn about,

  • Circular Linked List
  • Doubly Linked List
  • Doubly Circular Linked List

We have already learned singly linked list previously. You can kindly check my previous post if you haven't checked yet.

Moving on, Circular Linked List is basically the same concept of a Singly Linked List. However, instead of having an end node, we are going to recycle our path to the beginning node.

Circular01

Instead of keeping our last node's instance variable 'next node' equal to null, we are going to replace it with our beginning node location.

Circular02

Here, we linked our last node with the beginning node. Now, we can call it a circular linked list. Pseudo code is given below for clear understanding.

given head

current node = head
while current node.next node is not null {
    current node = current node.next node
}
current node.next node = head
Enter fullscreen mode Exit fullscreen mode

How do we find the end node of a circular linked list? We just simply look for head in our current node.

while current node.next node is not head {
    get current node.data
    current node = current node.next node
}
get current node.data //getting the data of the last node
Enter fullscreen mode Exit fullscreen mode

Moving on to Doubly Linked List. Up till now we learned about one way linked list. Doubly linked list is a two way linked list where I can move forward as well as backwards.

DLL01

Now, instead of having two instance variable in our node, we are going to have three instance variable. One extra variable for previous location to get backward access.

object Node {
    initialising variable (data) {
        data = data
        next node = null
        previous node = null
    }
}
Enter fullscreen mode Exit fullscreen mode

Making Link with the nodes. We keep our head's previous node location as null and Move on.

DLL02

Set the previous node value of node two to node one and so on.

DLL03

DLL04

Pseudo code is given below for better understanding.

given head

current node = head
while current node.next node is not null {
    temporary node = current node
    current node = current node.next node
    current node.previous node = temporary node
}
Enter fullscreen mode Exit fullscreen mode

We have successfully created a Doubly linked list. Now anywhere in the middle of our linked list we can have access to our previous nodes.

You can always make it sufficient in your ways. For example, you can set previous node value when you first time created your linked list and also many other ways.

Now we are left with Doubly Circular linked list. Pretty much same concept of a Circular linked list. Instead of having one way linked, we will now make a cycle with two ways.

DCLL

Here we linked the end node with the starting node and linked the starting node with the end node.

given head

current node = head
while current node.next node is not null {
    current node = current node.next node
}
current node.next node = head
head.previous node = current node
Enter fullscreen mode Exit fullscreen mode

Congratulations. We have successfully completed different types of linked lists. Later on I will write post about insertion and deletion methods.

Top comments (0)