刪除回圈雙向連結串列的末尾節點

2019-10-16 22:02:53

要刪除回圈雙向連結串列中的末尾節點,有兩種情況。

第一種情況,要刪除的節點可以是連結串列中唯一存在的節點。在這種情況下,條件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指標指向tempprev節點。

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