要刪除回圈雙向連結串列中的末尾節點,有兩種情況。
第一種情況,要刪除的節點可以是連結串列中唯一存在的節點。在這種情況下,條件head->next == head
將變為true
,因此需要完全刪除連結串列。
通過將連結串列的頭(head
)指標指定為null
並釋放頭指標來簡單地完成。
head = NULL;
free(head);
在第二種情況,連結串列包含多個元素,因此條件head->next == head
將變為false
。 現在,到達連結串列的最後一個節點並在那裡進行一些指標調整。 為此目的可以使用while
迴圈。
temp = head;
while(temp -> next != head)
{
temp = temp -> next;
}
現在,temp
將指向要在連結串列中刪除的節點。 建立上一個temp
節點的下一個指標,指向連結串列的頭節點。
temp -> prev -> next = head;
使頭節點的prev
指標指向temp
的prev
節點。
head -> prev = ptr -> prev;
接下來,釋放temp
指標以釋放節點占用的記憶體。
free(head)
以這種方式,就可以刪除連結串列的最後一個節點。
演算法
第1步:IF HEAD = NULL
提示記憶體溢位
轉到第8步
[IF結束]
第2步:設定TEMP = HEAD
第3步:在TEMP - > NEXT!= HEAD時重複第4步
第4步:設定TEMP = TEMP - > NEXT
[迴圈結束]
第5步:設定TEMP - > PREV - > NEXT = HEAD
第6步:SET HEAD - > PREV = TEMP - > PREV
第7步:釋放 TEMP
第8步:退出
示意圖
C語言實現的範例程式碼,如下所示 -
#include<stdio.h>
#include<stdlib.h>
void create(int);
void deletion_last();
struct node
{
int data;
struct node *next;
struct node *prev;
};
struct node *head;
void main()
{
int choice, item;
do
{
printf("1.Append List\n2.Delete Node from last\n3.Exit\n4.Enter your choice?");
scanf("%d", &choice);
switch (choice)
{
case 1:
printf("Enter the item\n");
scanf("%d", &item);
create(item);
break;
case 2:
deletion_last();
break;
case 3:
exit(0);
break;
default:
printf("Please Enter valid choice\n");
}
} while (choice != 3);
}
void create(int item)
{
struct node *ptr = (struct node *) malloc(sizeof(struct node));
struct node *temp;
if (ptr == NULL)
{
printf("OVERFLOW\n");
}
else
{
ptr->data = item;
if (head == NULL)
{
head = ptr;
ptr->next = head;
ptr->prev = head;
}
else
{
temp = head;
while (temp->next != head)
{
temp = temp->next;
}
temp->next = ptr;
ptr->prev = temp;
head->prev = ptr;
ptr->next = head;
}
}
printf("Node Inserted\n");
}
void deletion_last()
{
struct node *ptr;
if (head == NULL)
{
printf("UNDERFLOW\n");
}
else if (head->next == head)
{
head = NULL;
free(head);
printf("Node Deleted\n");
}
else
{
ptr = head;
if (ptr->next != head)
{
ptr = ptr->next;
}
ptr->prev->next = head;
head->prev = ptr->prev;
free(ptr);
printf("Node Deleted\n");
}
}
執行上面範例程式碼,得到以下結果 -
1.Append List
2.Delete Node from last
3.Exit
4.Enter your choice?1
Enter the item
12
Node Inserted
1.Append List
2.Delete Node from last
3.Exit
4.Enter your choice?2
Node Deleted