{"id":28788,"date":"2021-02-26T16:10:51","date_gmt":"2021-02-26T16:10:51","guid":{"rendered":"https:\/\/www.techolac.com\/?p=28788"},"modified":"2021-02-26T16:10:51","modified_gmt":"2021-02-26T16:10:51","slug":"understand-doubly-linked-list-c-with-illustration","status":"publish","type":"post","link":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/","title":{"rendered":"Understand Doubly Linked List C++ With Illustration"},"content":{"rendered":"<p>This post will explain doubly linked list c++. A twice as connected list is a variation of the singly linked list. We understand that the singly linked list is a collection of nodes, with each node having a data part and a pointer indicating the next node.<\/p>\n<p>A doubly connected list is also a collection of nodes. Each node here includes an information part and two pointers. One tip points to the previous node, while the second pointer indicates the next node.<\/p>\n<h2>Understand Doubly Linked List C++ With Illustration<\/h2>\n<p>In this article, you can know about doubly linked list c++ here are the details below;<\/p>\n<h2>Doubly Linked In C++<\/h2>\n<p>As in the singly connected list, the two times as connected list also has a head and a tail. The previous guideline of the head is set to NULL as this is the very first node. The next pointers of the tail node is set to NULL as this is the last node.<br \/>\nA basic layout of the two times as connected list is displayed in the below diagram.<\/p>\n<p>In the above figures, we see that each node has two pointers, pointing to the previous node and the other indicating the next node. Only the primary node (head) has its previous nodes set to null, and the last node (tail) has its next pointers set to null. You can also check<a href=\"https:\/\/www.techolac.com\/best-ihome-speakers\/\"> best ihome speakers<\/a>.<\/p>\n<p>As the doubly connected list contains two pointers, i.e., previous and next, we can traverse it into the instructions forward and backward. This is the primary benefit of two times as a linked list over the singly connected list.<\/p>\n<h2>Declaration<\/h2>\n<p>In C-style declaration, a nodes of the doubly linked list is represented as follows:<br \/>\nstruct node<br \/>\n;<br \/>\nApart from the above declaration, we can likewise represent a node in the doubly linked list as a classes in C++. A doubly connected list is represented as a class when we utilize STL in C++. We can execute a twice as linked list using a class in Java too.<\/p>\n<h2>Basic Operations<\/h2>\n<p>Following are some of the operation&#8217;s that we can perform two times as a connected list.<br \/>\nInsertion<br \/>\nInsertion operation of the twice as connected list inserts a brand-new node in the linked list. Depending opon the position where the new node is to be placed, we can have the following<\/p>\n<h2>insert operations.<\/h2>\n<p>&#8211; Insertion at the front&#8211; Inserts a brand-new node as the first node.<br \/>\n&#8211; Insertion at the end&#8211; Inserts a brand-new node at the end as the last node.<br \/>\n&#8211; Insertion before a node&#8211; Given a node, inserts a new node before this node.<br \/>\n&#8211; Insertion after a node&#8211; Given a node, inserts a new node after this node.<\/p>\n<h2>Deletion<\/h2>\n<p>Deletion operation deletes a node from a provided position in the twice as connected list<br \/>\n&#8211; Deletion of the first node&#8211; Deletes the very first node in the list.<br \/>\n&#8211; Deletion of the last node&#8211; Deletes the last node in the list.<br \/>\nDeleting a node given the information: Given the information, the operation matches the data with the node information in the linked list and deletes that node.<\/p>\n<h2>Traversal<\/h2>\n<p>Traversal is a strategy of going to each node in the connected list. In a twice as connected list, we have two kinds of traversals as we have two guidelines with various instructions in the two times as linked list.<br \/>\n&#8211; Forward Traversal&#8211; Traversal is done using the next tip, which is in the forward instructions.<br \/>\n&#8211; Backward Traversal&#8211; Traversal is done utilizing the previous guideline, which is the backward direction.<\/p>\n<h2>Reverse<\/h2>\n<p>This operation reverses the nodes in the two times as linked list so that the first node becomes the last nodes while the last node becomes the first node.<\/p>\n<h2>Search<\/h2>\n<p>Search operation in the doubly connected list is used to look for a specific node in the linked list. For this purpose, we require to traverse the list until matching information is found.<\/p>\n<h2>Insertion<\/h2>\n<p>Insert a node at the front<\/p>\n<p>The insertion of a new nodes at the front of the list is shown above. As seen, the previous brand-new node N is set to null. Head points to the new node. The next tip now indicates N1, and the previous of N1 that was earlier pointing to Null now indicates N.<br \/>\nInsert node at the end<\/p>\n<p>Inserting a nodes at the end of the two times as linked list is attained by pointing the next node N to null. The premature pointer of N is pointed to N5. The &#8216;Next&#8217; tip of N5 is pointed to N.<\/p>\n<h2>Insert node before\/after given node<\/h2>\n<p>As shown in the aboves diagram, when we need to include a node before or after a particular node, we alter the previous and next guidelines of the before and after nodes to properly indicate the new node. Likewise, the brand-new node guidelines are appropriately pointed to the existing nodes. Also check <a href=\"https:\/\/www.techolac.com\/textsheet-alternatives\/\">textsheet alternatives<\/a>.<\/p>\n<h2>The following C++ program shows all the above methods to insert nodes in the twice as linked list.<\/h2>\n<div>\n<div id=\"highlighter_982346\" class=\"syntaxhighlighter nogutter  cpp\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"cpp preprocessor\">#include &lt;iostream&gt;<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"cpp keyword bold\">using<\/code> <code class=\"cpp keyword bold\">namespace<\/code> <code class=\"cpp plain\">std;<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"cpp comments\">\/\/ A doubly linked list node<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node {<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">data;<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* next;<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* prev;<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"cpp plain\">};<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"cpp comments\">\/\/inserts node at the front of the list<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">insert_front(<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node** head, <\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">new_data)<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"cpp plain\">{<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/allocate memory for New node<\/code><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* newNode = <\/code><code class=\"cpp keyword bold\">new<\/code> <code class=\"cpp plain\">Node;<\/code><\/div>\n<div class=\"line number16 index15 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number17 index16 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/assign data to new node<\/code><\/div>\n<div class=\"line number18 index17 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;data = new_data;<\/code><\/div>\n<div class=\"line number19 index18 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number20 index19 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/new node is head and previous is null, since we are adding at the front<\/code><\/div>\n<div class=\"line number21 index20 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;next = (*head);<\/code><\/div>\n<div class=\"line number22 index21 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;prev = NULL;<\/code><\/div>\n<div class=\"line number23 index22 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number24 index23 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/previous of head is new node<\/code><\/div>\n<div class=\"line number25 index24 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code> <code class=\"cpp plain\">((*head) != NULL)<\/code><\/div>\n<div class=\"line number26 index25 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">(*head)-&gt;prev = newNode;<\/code><\/div>\n<div class=\"line number27 index26 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number28 index27 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/head points to new node<\/code><\/div>\n<div class=\"line number29 index28 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">(*head) = newNode;<\/code><\/div>\n<div class=\"line number30 index29 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number31 index30 alt2\"><code class=\"cpp comments\">\/* Given a node as prev_node, insert a new node after the given node *\/<\/code><\/div>\n<div class=\"line number32 index31 alt1\"><code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">insert_After(<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* prev_node, <\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">new_data)<\/code><\/div>\n<div class=\"line number33 index32 alt2\"><code class=\"cpp plain\">{<\/code><\/div>\n<div class=\"line number34 index33 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/check if prev node is null<\/code><\/div>\n<div class=\"line number35 index34 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code> <code class=\"cpp plain\">(prev_node == NULL) {<\/code><\/div>\n<div class=\"line number36 index35 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">cout&lt;&lt;<\/code><code class=\"cpp string\">\"Previous node is required , it cannot be NULL\"<\/code><code class=\"cpp plain\">;<\/code><\/div>\n<div class=\"line number37 index36 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">return<\/code><code class=\"cpp plain\">;<\/code><\/div>\n<div class=\"line number38 index37 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number39 index38 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/allocate memory for new node<\/code><\/div>\n<div class=\"line number40 index39 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* newNode = <\/code><code class=\"cpp keyword bold\">new<\/code> <code class=\"cpp plain\">Node;<\/code><\/div>\n<div class=\"line number41 index40 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number42 index41 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/assign data to new node<\/code><\/div>\n<div class=\"line number43 index42 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;data = new_data;<\/code><\/div>\n<div class=\"line number44 index43 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number45 index44 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set next of newnode to next of prev node<\/code><\/div>\n<div class=\"line number46 index45 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;next = prev_node-&gt;next;<\/code><\/div>\n<div class=\"line number47 index46 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number48 index47 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set next of prev node to newnode<\/code><\/div>\n<div class=\"line number49 index48 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">prev_node-&gt;next = newNode;<\/code><\/div>\n<div class=\"line number50 index49 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number51 index50 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/now set prev of newnode to prev node<\/code><\/div>\n<div class=\"line number52 index51 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;prev = prev_node;<\/code><\/div>\n<div class=\"line number53 index52 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number54 index53 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set prev of new node's next to newnode<\/code><\/div>\n<div class=\"line number55 index54 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code> <code class=\"cpp plain\">(newNode-&gt;next != NULL)<\/code><\/div>\n<div class=\"line number56 index55 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;next-&gt;prev = newNode;<\/code><\/div>\n<div class=\"line number57 index56 alt2\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number58 index57 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number59 index58 alt2\"><code class=\"cpp comments\">\/\/insert a new node at the end of the list<\/code><\/div>\n<div class=\"line number60 index59 alt1\"><code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">insert_end(<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node** head, <\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">new_data)<\/code><\/div>\n<div class=\"line number61 index60 alt2\"><code class=\"cpp plain\">{<\/code><\/div>\n<div class=\"line number62 index61 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/allocate memory for node<\/code><\/div>\n<div class=\"line number63 index62 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* newNode = <\/code><code class=\"cpp keyword bold\">new<\/code> <code class=\"cpp plain\">Node;<\/code><\/div>\n<div class=\"line number64 index63 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number65 index64 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* last = *head; <\/code><code class=\"cpp comments\">\/\/set last node value to head<\/code><\/div>\n<div class=\"line number66 index65 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number67 index66 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set data for new node<\/code><\/div>\n<div class=\"line number68 index67 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;data = new_data;<\/code><\/div>\n<div class=\"line number69 index68 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number70 index69 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/new node is the last node , so set next of new node to null<\/code><\/div>\n<div class=\"line number71 index70 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;next = NULL;<\/code><\/div>\n<div class=\"line number72 index71 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number73 index72 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/check if list is empty, if yes make new node the head of list<\/code><\/div>\n<div class=\"line number74 index73 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code> <code class=\"cpp plain\">(*head == NULL) {<\/code><\/div>\n<div class=\"line number75 index74 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode-&gt;prev = NULL;<\/code><\/div>\n<div class=\"line number76 index75 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">*head = newNode;<\/code><\/div>\n<div class=\"line number77 index76 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">return<\/code><code class=\"cpp plain\">;<\/code><\/div>\n<div class=\"line number78 index77 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number79 index78 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number80 index79 alt1\"><code class=\"cpp comments\">\/\/otherwise traverse the list to go to last node<\/code><\/div>\n<div class=\"line number81 index80 alt2\"><code class=\"cpp keyword bold\">while<\/code> <code class=\"cpp plain\">(last-&gt;next != NULL)<\/code><\/div>\n<div class=\"line number82 index81 alt1\"><code class=\"cpp plain\">last = last-&gt;next;<\/code><\/div>\n<div class=\"line number83 index82 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number84 index83 alt1\"><code class=\"cpp comments\">\/\/set next of last to new node<\/code><\/div>\n<div class=\"line number85 index84 alt2\"><code class=\"cpp plain\">last-&gt;next = newNode;<\/code><\/div>\n<div class=\"line number86 index85 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number87 index86 alt2\"><code class=\"cpp comments\">\/\/set last to prev of new node<\/code><\/div>\n<div class=\"line number88 index87 alt1\"><code class=\"cpp plain\">newNode-&gt;prev = last;<\/code><\/div>\n<div class=\"line number89 index88 alt2\"><code class=\"cpp keyword bold\">return<\/code><code class=\"cpp plain\">;<\/code><\/div>\n<div class=\"line number90 index89 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number91 index90 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number92 index91 alt1\"><code class=\"cpp comments\">\/\/ This function prints contents of linked list starting from the given node<\/code><\/div>\n<div class=\"line number93 index92 alt2\"><code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">displayList(<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* node) {<\/code><\/div>\n<div class=\"line number94 index93 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* last;<\/code><\/div>\n<div class=\"line number95 index94 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number96 index95 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">while<\/code> <code class=\"cpp plain\">(node != NULL) {<\/code><\/div>\n<div class=\"line number97 index96 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">cout&lt;&lt;node-&gt;data&lt;&lt;<\/code><code class=\"cpp string\">\"&lt;==&gt;\"<\/code><code class=\"cpp plain\">;<\/code><\/div>\n<div class=\"line number98 index97 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">last = node;<\/code><\/div>\n<div class=\"line number99 index98 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">node = node-&gt;next;<\/code><\/div>\n<div class=\"line number100 index99 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number101 index100 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code><code class=\"cpp plain\">(node == NULL)<\/code><\/div>\n<div class=\"line number102 index101 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">cout&lt;&lt;<\/code><code class=\"cpp string\">\"NULL\"<\/code><code class=\"cpp plain\">;<\/code><\/div>\n<div class=\"line number103 index102 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number104 index103 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number105 index104 alt2\"><code class=\"cpp comments\">\/\/main program<\/code><\/div>\n<div class=\"line number106 index105 alt1\"><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">main() {<\/code><\/div>\n<div class=\"line number107 index106 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/* Start with the empty list *\/<\/code><\/div>\n<div class=\"line number108 index107 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">struct<\/code> <code class=\"cpp plain\">Node* head = NULL;<\/code><\/div>\n<div class=\"line number109 index108 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number110 index109 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 40 as last node<\/code><\/div>\n<div class=\"line number111 index110 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">insert_end(&amp;head, 40);<\/code><\/div>\n<div class=\"line number112 index111 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number113 index112 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ insert 20 at the head<\/code><\/div>\n<div class=\"line number114 index113 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">insert_front(&amp;head, 20);<\/code><\/div>\n<div class=\"line number115 index114 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number116 index115 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 10 at the beginning.<\/code><\/div>\n<div class=\"line number117 index116 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">insert_front(&amp;head, 10);<\/code><\/div>\n<div class=\"line number118 index117 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number119 index118 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 50 at the end.<\/code><\/div>\n<div class=\"line number120 index119 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">insert_end(&amp;head, 50);<\/code><\/div>\n<div class=\"line number121 index120 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number122 index121 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 30, after 20.<\/code><\/div>\n<div class=\"line number123 index122 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">insert_After(head-&gt;next, 30);<\/code><\/div>\n<div class=\"line number124 index123 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number125 index124 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">cout&lt;&lt;<\/code><code class=\"cpp string\">\"Doubly linked list is as follows: \"<\/code><code class=\"cpp plain\">&lt;&lt;endl;<\/code><\/div>\n<div class=\"line number126 index125 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">displayList(head);<\/code><\/div>\n<div class=\"line number127 index126 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">return<\/code> <code class=\"cpp plain\">0;<\/code><\/div>\n<div class=\"line number128 index127 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<p>A node can be erased from a twice as connected list from any position like the front, end, or any other offered position or offered information.<br \/>\nWhen deleting a node from the doubly connected list, we first reposition the pointer indicating that particular node. The previous and after nodes don&#8217;t have any connection to the node to be deleted. We can then quickly erase the node.<\/p>\n<p>Consider the following two times as a connected list with three nodes A, B, C. Let us consider that we require to erase node B.<\/p>\n<p>As displayed in the diagram above, we have demonstrated the deletion of node B from the provided connected list. The series of operations remains the same even if the node is 1st or last. The only care that should be considered is that if the first node is erased, the second node&#8217;s previous pointer will be null.<\/p>\n<p>Likewise, when the last node is deleted, the previous node&#8217;s next pointer will be set to null. If in-between nodes are deleted, then the sequence will be as above.<br \/>\nWe leave the programs to delete a node from two times as a linked list. Note thats the implementation will be on the line&#8217;s of the insertion implementation. Also check <a href=\"https:\/\/www.techolac.com\/wow-private-servers\/\">wow private servers<\/a>.<\/p>\n<h2>Reverse Doubly Linked List.<\/h2>\n<p>Reversing two times as a linked list is a crucial operation. In this, we just swap the previous and next tips of all the nodes and likewise switch the head and tail guidelines.<br \/>\nProvided listed below is a doubly connected list:<\/p>\n<div>\n<div id=\"highlighter_534512\" class=\"syntaxhighlighter nogutter  cpp\">\n<table border=\"0\" cellspacing=\"0\" cellpadding=\"0\">\n<tbody>\n<tr>\n<td class=\"code\">\n<div class=\"container\">\n<div class=\"line number1 index0 alt2\"><code class=\"cpp comments\">\/\/ Java Class for Doubly Linked List<\/code><\/div>\n<div class=\"line number2 index1 alt1\"><code class=\"cpp keyword bold\">class<\/code> <code class=\"cpp plain\">Doubly_linkedList {<\/code><\/div>\n<div class=\"line number3 index2 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node head; <\/code><code class=\"cpp comments\">\/\/ list head<\/code><\/div>\n<div class=\"line number4 index3 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number5 index4 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/* Doubly Linked list Node*\/<\/code><\/div>\n<div class=\"line number6 index5 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">class<\/code> <code class=\"cpp plain\">Node {<\/code><\/div>\n<div class=\"line number7 index6 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">data;<\/code><\/div>\n<div class=\"line number8 index7 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node prev;<\/code><\/div>\n<div class=\"line number9 index8 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node next;<\/code><\/div>\n<div class=\"line number10 index9 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number11 index10 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/create a new node using constructor<\/code><\/div>\n<div class=\"line number12 index11 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node(<\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">d) { data = d; }<\/code><\/div>\n<div class=\"line number13 index12 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number14 index13 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number15 index14 alt2\"><code class=\"cpp comments\">\/\/ insert a node at the front of the list<\/code><\/div>\n<div class=\"line number16 index15 alt1\"><code class=\"cpp keyword bold\">public<\/code> <code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">insert_front(<\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">new_data)<\/code><\/div>\n<div class=\"line number17 index16 alt2\"><code class=\"cpp plain\">{<\/code><\/div>\n<div class=\"line number18 index17 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/* 1. allocate node<\/code><\/div>\n<div class=\"line number19 index18 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">* 2. put in the data *\/<\/code><\/div>\n<div class=\"line number20 index19 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node new_Node = <\/code><code class=\"cpp keyword bold\">new<\/code> <code class=\"cpp plain\">Node(new_data);<\/code><\/div>\n<div class=\"line number21 index20 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number22 index21 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/* 3. Make next of new node as head and previous as NULL *\/<\/code><\/div>\n<div class=\"line number23 index22 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">new_Node.next = head;<\/code><\/div>\n<div class=\"line number24 index23 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">new_Node.prev = null;<\/code><\/div>\n<div class=\"line number25 index24 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number26 index25 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/* 4. change prev of head node to new node *\/<\/code><\/div>\n<div class=\"line number27 index26 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code> <code class=\"cpp plain\">(head != null)<\/code><\/div>\n<div class=\"line number28 index27 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">head.prev = new_Node;<\/code><\/div>\n<div class=\"line number29 index28 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number30 index29 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/* 5. move the head to point to the new node *\/<\/code><\/div>\n<div class=\"line number31 index30 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">head = new_Node;<\/code><\/div>\n<div class=\"line number32 index31 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number33 index32 alt2\"><code class=\"cpp comments\">\/\/insert a node after the given prev node<\/code><\/div>\n<div class=\"line number34 index33 alt1\"><code class=\"cpp keyword bold\">public<\/code> <code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">Insert_After(Node prev_Node, <\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">new_data)<\/code><\/div>\n<div class=\"line number35 index34 alt2\"><code class=\"cpp plain\">{<\/code><\/div>\n<div class=\"line number36 index35 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/check that prev node is not null<\/code><\/div>\n<div class=\"line number37 index36 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code> <code class=\"cpp plain\">(prev_Node == null) {<\/code><\/div>\n<div class=\"line number38 index37 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">System.out.println(<\/code><code class=\"cpp string\">\"The previous node is required,it cannot be NULL \"<\/code><code class=\"cpp plain\">);<\/code><\/div>\n<div class=\"line number39 index38 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">return<\/code><code class=\"cpp plain\">;<\/code><\/div>\n<div class=\"line number40 index39 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number41 index40 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number42 index41 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/allocate new node and set it to data<\/code><\/div>\n<div class=\"line number43 index42 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node newNode = <\/code><code class=\"cpp keyword bold\">new<\/code> <code class=\"cpp plain\">Node(new_data);<\/code><\/div>\n<div class=\"line number44 index43 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number45 index44 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set next of newNode as next of prev node<\/code><\/div>\n<div class=\"line number46 index45 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode.next = prev_Node.next;<\/code><\/div>\n<div class=\"line number47 index46 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number48 index47 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set new node to next of prev node<\/code><\/div>\n<div class=\"line number49 index48 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">prev_Node.next = newNode;<\/code><\/div>\n<div class=\"line number50 index49 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number51 index50 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set prev of newNode as prev node<\/code><\/div>\n<div class=\"line number52 index51 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode.prev = prev_Node;<\/code><\/div>\n<div class=\"line number53 index52 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number54 index53 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set prev of new node's next to newnode<\/code><\/div>\n<div class=\"line number55 index54 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code> <code class=\"cpp plain\">(newNode.next != null)<\/code><\/div>\n<div class=\"line number56 index55 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode.next.prev = newNode;<\/code><\/div>\n<div class=\"line number57 index56 alt2\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number58 index57 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number59 index58 alt2\"><code class=\"cpp comments\">\/\/ Add a node at the end of the list<\/code><\/div>\n<div class=\"line number60 index59 alt1\"><code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">insert_end(<\/code><code class=\"cpp color1 bold\">int<\/code> <code class=\"cpp plain\">new_data)\u00a0\u00a0 {<\/code><\/div>\n<div class=\"line number61 index60 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/allocate the node and set the data<\/code><\/div>\n<div class=\"line number62 index61 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node newNode = <\/code><code class=\"cpp keyword bold\">new<\/code> <code class=\"cpp plain\">Node(new_data);<\/code><\/div>\n<div class=\"line number63 index62 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node last = head; <\/code><code class=\"cpp comments\">\/\/set last as the head<\/code><\/div>\n<div class=\"line number64 index63 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set next of new node to null since its the last node<\/code><\/div>\n<div class=\"line number65 index64 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode.next = null;<\/code><\/div>\n<div class=\"line number66 index65 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number67 index66 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/set new node as head if the list is null<\/code><\/div>\n<div class=\"line number68 index67 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code> <code class=\"cpp plain\">(head == null) {<\/code><\/div>\n<div class=\"line number69 index68 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode.prev = null;<\/code><\/div>\n<div class=\"line number70 index69 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">head = newNode;<\/code><\/div>\n<div class=\"line number71 index70 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">return<\/code><code class=\"cpp plain\">;<\/code><\/div>\n<div class=\"line number72 index71 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number73 index72 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/if list is not null then traverse it till the last node and set last next to last<\/code><\/div>\n<div class=\"line number74 index73 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">while<\/code> <code class=\"cpp plain\">(last.next != null)<\/code><\/div>\n<div class=\"line number75 index74 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">last = last.next;<\/code><\/div>\n<div class=\"line number76 index75 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number77 index76 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">last.next = newNode; \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 <\/code><code class=\"cpp comments\">\/\/set last next to new node<\/code><\/div>\n<div class=\"line number78 index77 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number79 index78 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">newNode.prev = last; \u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0 \u00a0<\/code><code class=\"cpp comments\">\/\/set last as prev of new node<\/code><\/div>\n<div class=\"line number80 index79 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number81 index80 alt2\"><code class=\"cpp comments\">\/\/ display the contents of linked list starting from the given node<\/code><\/div>\n<div class=\"line number82 index81 alt1\"><code class=\"cpp keyword bold\">public<\/code> <code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">displaylist(Node node)<\/code><\/div>\n<div class=\"line number83 index82 alt2\"><code class=\"cpp plain\">{<\/code><\/div>\n<div class=\"line number84 index83 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Node last = null;<\/code><\/div>\n<div class=\"line number85 index84 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">while<\/code> <code class=\"cpp plain\">(node != null) {<\/code><\/div>\n<div class=\"line number86 index85 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">System.out.print(node.data + <\/code><code class=\"cpp string\">\"&lt;==&gt;\"<\/code><code class=\"cpp plain\">);<\/code><\/div>\n<div class=\"line number87 index86 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">last = node;<\/code><\/div>\n<div class=\"line number88 index87 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">node = node.next;<\/code><\/div>\n<div class=\"line number89 index88 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number90 index89 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">if<\/code><code class=\"cpp plain\">(node == null)<\/code><\/div>\n<div class=\"line number91 index90 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">System.out.print(<\/code><code class=\"cpp string\">\"null\"<\/code><code class=\"cpp plain\">);<\/code><\/div>\n<div class=\"line number92 index91 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">System.out.println();<\/code><\/div>\n<div class=\"line number93 index92 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number94 index93 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number95 index94 alt2\"><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number96 index95 alt1\"><code class=\"cpp keyword bold\">class<\/code> <code class=\"cpp plain\">Main{<\/code><\/div>\n<div class=\"line number97 index96 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0<\/code><code class=\"cpp keyword bold\">public<\/code> <code class=\"cpp keyword bold\">static<\/code> <code class=\"cpp keyword bold\">void<\/code> <code class=\"cpp plain\">main(String[] args)<\/code><\/div>\n<div class=\"line number98 index97 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">{<\/code><\/div>\n<div class=\"line number99 index98 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/* Start with the empty list *\/<\/code><\/div>\n<div class=\"line number100 index99 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">Doubly_linkedList dll = <\/code><code class=\"cpp keyword bold\">new<\/code> <code class=\"cpp plain\">Doubly_linkedList();<\/code><\/div>\n<div class=\"line number101 index100 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number102 index101 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 40.<\/code><\/div>\n<div class=\"line number103 index102 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">dll.insert_end(40);<\/code><\/div>\n<div class=\"line number104 index103 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number105 index104 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 20 at the beginning.<\/code><\/div>\n<div class=\"line number106 index105 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">dll.insert_front(20);<\/code><\/div>\n<div class=\"line number107 index106 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number108 index107 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 10 at the beginning.<\/code><\/div>\n<div class=\"line number109 index108 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">dll.insert_front(10);<\/code><\/div>\n<div class=\"line number110 index109 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number111 index110 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 50 at the end.<\/code><\/div>\n<div class=\"line number112 index111 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">dll.insert_end(50);<\/code><\/div>\n<div class=\"line number113 index112 alt2\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number114 index113 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp comments\">\/\/ Insert 30, after 20.<\/code><\/div>\n<div class=\"line number115 index114 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">dll.Insert_After(dll.head.next, 30);<\/code><\/div>\n<div class=\"line number116 index115 alt1\"><code class=\"cpp spaces\">\u00a0<\/code><\/div>\n<div class=\"line number117 index116 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">System.out.println(<\/code><code class=\"cpp string\">\"Doubly linked list created is as follows: \"<\/code><code class=\"cpp plain\">);<\/code><\/div>\n<div class=\"line number118 index117 alt1\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">dll.displaylist(dll.head);<\/code><\/div>\n<div class=\"line number119 index118 alt2\"><code class=\"cpp spaces\">\u00a0\u00a0\u00a0\u00a0\u00a0\u00a0<\/code><code class=\"cpp plain\">}<\/code><\/div>\n<div class=\"line number120 index119 alt1\"><code class=\"cpp plain\">}<\/code><\/div>\n<\/div>\n<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<\/div>\n<\/div>\n<h2>Benefits:<\/h2>\n<p>&#8211; The doubly linked list can be traverseds in forward and backward directions, unlike singly connected list which can be passed through in the forward direction just.<br \/>\n&#8211; Delete operation in a doubly-linked lists is more efficient when compared to a singly note when a provided node is given. As we require a previous node to erase the provided node in a singly linked list, we often need to traverse the list to discover the previous node. This hits the performance.<br \/>\n&#8211; Insertion operation can be done quickly in two times as linked to the singly connected list.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>This post will explain doubly linked list c++. A twice as connected list is a variation of the singly linked list. We understand that the singly linked list is a collection of nodes, with each node having a data part and a pointer indicating the next node. A doubly connected list is also a collection [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":28789,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[24,26],"tags":[3873],"class_list":["post-28788","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-internet","category-linux","tag-doubly-linked-list-c"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v26.8 - https:\/\/yoast.com\/product\/yoast-seo-wordpress\/ -->\n<title>Understand Doubly Linked List C++ With Illustration - Techolac<\/title>\n<meta name=\"description\" content=\"Understand Doubly Linked List C++ With Illustration. This post will explain doubly linked list c++. A twice as connected list is a variation\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Understand Doubly Linked List C++ With Illustration - Techolac\" \/>\n<meta property=\"og:description\" content=\"Understand Doubly Linked List C++ With Illustration. This post will explain doubly linked list c++. A twice as connected list is a variation\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/\" \/>\n<meta property=\"og:site_name\" content=\"Techolac - Computer Technology News\" \/>\n<meta property=\"article:published_time\" content=\"2021-02-26T16:10:51+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png\" \/>\n\t<meta property=\"og:image:width\" content=\"1039\" \/>\n\t<meta property=\"og:image:height\" content=\"583\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/png\" \/>\n<meta name=\"author\" content=\"Luke\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Luke\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"10 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#article\",\"isPartOf\":{\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/\"},\"author\":{\"name\":\"Luke\",\"@id\":\"https:\/\/www.techolac.com\/#\/schema\/person\/c10974df2877dee6ed1da15511093444\"},\"headline\":\"Understand Doubly Linked List C++ With Illustration\",\"datePublished\":\"2021-02-26T16:10:51+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/\"},\"wordCount\":1207,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\/\/www.techolac.com\/#\/schema\/person\/3c09b621dfc5ef8f09b6f48236a9ae7b\"},\"image\":{\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png\",\"keywords\":[\"doubly linked list c++\"],\"articleSection\":[\"Internet\",\"Linux\"],\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/\",\"url\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/\",\"name\":\"Understand Doubly Linked List C++ With Illustration - Techolac\",\"isPartOf\":{\"@id\":\"https:\/\/www.techolac.com\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#primaryimage\"},\"image\":{\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#primaryimage\"},\"thumbnailUrl\":\"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png\",\"datePublished\":\"2021-02-26T16:10:51+00:00\",\"description\":\"Understand Doubly Linked List C++ With Illustration. This post will explain doubly linked list c++. A twice as connected list is a variation\",\"breadcrumb\":{\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#breadcrumb\"},\"inLanguage\":\"en-US\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#primaryimage\",\"url\":\"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png\",\"contentUrl\":\"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png\",\"width\":1039,\"height\":583,\"caption\":\"doubly linked list c++\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\/\/www.techolac.com\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Understand Doubly Linked List C++ With Illustration\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.techolac.com\/#website\",\"url\":\"https:\/\/www.techolac.com\/\",\"name\":\"Techolac - Computer Technology News\",\"description\":\"A weblog on emerging technology and internet news, reviews, tips for a broad range of computing technologies.\",\"publisher\":{\"@id\":\"https:\/\/www.techolac.com\/#\/schema\/person\/3c09b621dfc5ef8f09b6f48236a9ae7b\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.techolac.com\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"en-US\"},{\"@type\":[\"Person\",\"Organization\"],\"@id\":\"https:\/\/www.techolac.com\/#\/schema\/person\/3c09b621dfc5ef8f09b6f48236a9ae7b\",\"name\":\"Editorial Staff\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.techolac.com\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/46bb6cbf5ea4efe79156ff0f5de0a9602d1d0e5da0cb54b21e05a35d7e23379c?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/46bb6cbf5ea4efe79156ff0f5de0a9602d1d0e5da0cb54b21e05a35d7e23379c?s=96&d=mm&r=g\",\"caption\":\"Editorial Staff\"},\"logo\":{\"@id\":\"https:\/\/www.techolac.com\/#\/schema\/person\/image\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.techolac.com\/#\/schema\/person\/c10974df2877dee6ed1da15511093444\",\"name\":\"Luke\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"en-US\",\"@id\":\"https:\/\/www.techolac.com\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/secure.gravatar.com\/avatar\/60a61099026e572b4ef7ca8eb0423230ce1840478525b72d1598d793882c7ce7?s=96&d=mm&r=g\",\"contentUrl\":\"https:\/\/secure.gravatar.com\/avatar\/60a61099026e572b4ef7ca8eb0423230ce1840478525b72d1598d793882c7ce7?s=96&d=mm&r=g\",\"caption\":\"Luke\"},\"url\":\"https:\/\/www.techolac.com\/author\/luke\/\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"Understand Doubly Linked List C++ With Illustration - Techolac","description":"Understand Doubly Linked List C++ With Illustration. This post will explain doubly linked list c++. A twice as connected list is a variation","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/","og_locale":"en_US","og_type":"article","og_title":"Understand Doubly Linked List C++ With Illustration - Techolac","og_description":"Understand Doubly Linked List C++ With Illustration. This post will explain doubly linked list c++. A twice as connected list is a variation","og_url":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/","og_site_name":"Techolac - Computer Technology News","article_published_time":"2021-02-26T16:10:51+00:00","og_image":[{"width":1039,"height":583,"url":"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png","type":"image\/png"}],"author":"Luke","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Luke","Est. reading time":"10 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#article","isPartOf":{"@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/"},"author":{"name":"Luke","@id":"https:\/\/www.techolac.com\/#\/schema\/person\/c10974df2877dee6ed1da15511093444"},"headline":"Understand Doubly Linked List C++ With Illustration","datePublished":"2021-02-26T16:10:51+00:00","mainEntityOfPage":{"@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/"},"wordCount":1207,"commentCount":0,"publisher":{"@id":"https:\/\/www.techolac.com\/#\/schema\/person\/3c09b621dfc5ef8f09b6f48236a9ae7b"},"image":{"@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#primaryimage"},"thumbnailUrl":"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png","keywords":["doubly linked list c++"],"articleSection":["Internet","Linux"],"inLanguage":"en-US","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/www.techolac.com\/doubly-linked-list-c-\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/","url":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/","name":"Understand Doubly Linked List C++ With Illustration - Techolac","isPartOf":{"@id":"https:\/\/www.techolac.com\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#primaryimage"},"image":{"@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#primaryimage"},"thumbnailUrl":"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png","datePublished":"2021-02-26T16:10:51+00:00","description":"Understand Doubly Linked List C++ With Illustration. This post will explain doubly linked list c++. A twice as connected list is a variation","breadcrumb":{"@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#breadcrumb"},"inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.techolac.com\/doubly-linked-list-c-\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#primaryimage","url":"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png","contentUrl":"https:\/\/www.techolac.com\/wp-content\/uploads\/2021\/02\/Screenshot-2020-10-09-at-5.15.30-PM.png","width":1039,"height":583,"caption":"doubly linked list c++"},{"@type":"BreadcrumbList","@id":"https:\/\/www.techolac.com\/doubly-linked-list-c-\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/www.techolac.com\/"},{"@type":"ListItem","position":2,"name":"Understand Doubly Linked List C++ With Illustration"}]},{"@type":"WebSite","@id":"https:\/\/www.techolac.com\/#website","url":"https:\/\/www.techolac.com\/","name":"Techolac - Computer Technology News","description":"A weblog on emerging technology and internet news, reviews, tips for a broad range of computing technologies.","publisher":{"@id":"https:\/\/www.techolac.com\/#\/schema\/person\/3c09b621dfc5ef8f09b6f48236a9ae7b"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.techolac.com\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":["Person","Organization"],"@id":"https:\/\/www.techolac.com\/#\/schema\/person\/3c09b621dfc5ef8f09b6f48236a9ae7b","name":"Editorial Staff","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.techolac.com\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/46bb6cbf5ea4efe79156ff0f5de0a9602d1d0e5da0cb54b21e05a35d7e23379c?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/46bb6cbf5ea4efe79156ff0f5de0a9602d1d0e5da0cb54b21e05a35d7e23379c?s=96&d=mm&r=g","caption":"Editorial Staff"},"logo":{"@id":"https:\/\/www.techolac.com\/#\/schema\/person\/image\/"}},{"@type":"Person","@id":"https:\/\/www.techolac.com\/#\/schema\/person\/c10974df2877dee6ed1da15511093444","name":"Luke","image":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.techolac.com\/#\/schema\/person\/image\/","url":"https:\/\/secure.gravatar.com\/avatar\/60a61099026e572b4ef7ca8eb0423230ce1840478525b72d1598d793882c7ce7?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/60a61099026e572b4ef7ca8eb0423230ce1840478525b72d1598d793882c7ce7?s=96&d=mm&r=g","caption":"Luke"},"url":"https:\/\/www.techolac.com\/author\/luke\/"}]}},"amp_enabled":true,"_links":{"self":[{"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/posts\/28788","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/comments?post=28788"}],"version-history":[{"count":3,"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/posts\/28788\/revisions"}],"predecessor-version":[{"id":28792,"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/posts\/28788\/revisions\/28792"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/media\/28789"}],"wp:attachment":[{"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/media?parent=28788"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/categories?post=28788"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.techolac.com\/wp-json\/wp\/v2\/tags?post=28788"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}