Circular Doubly Linked List
Basic operations for a circular doubly linked list.
Inserting a Node :
void insert(struct node *ptr, int data, int pos) {
// Creating a node
struct node *newNode;
newNode = (struct node *)malloc(sizeof(struct node));
newNode -> data = data;
// If node needs to be inserted at first position
if (pos == 1) {
if (head == NULL) {
// If linked list is empty
head = newNode;
head -> prev = head;
head -> next = head;
} else {
// If other nodes are present
newNode -> prev = head -> prev;
newNode -> next = head;
head -> prev = newNode;
newNode -> prev -> next = newNode;
head = newNode;
}
}
// If node is to be inserted at any other position
else {
for (int i = 0; i < pos - 2; i++) {
ptr = ptr -> next;
}
// Change the links
newNode -> next = ptr -> next;
newNode -> prev = ptr;
ptr -> next -> prev = newNode;
ptr -> next = newNode;
}
}Deleting a Node :
Displaying the Nodes :
Contributed by Nitin Ranganath
Last updated
Was this helpful?