刪除迴圈單連結串列開頭元素

2019-10-16 22:02:58

要刪除迴圈單連結串列中的開頭節點,需要進行一些指標調整。

在開頭有三種從迴圈單連結串列中刪除節點的方案有以下幾種。

情況1 :(連結串列為空)

如果連結串列為空,則條件head == NULL將變為true,在這種情況下,只需要在螢幕上列印下溢並退出。

if(head == NULL)
{  
    printf("UNDERFLOW\n");
    return;
}

情況2 :(連結串列包含單個節點)

如果連結串列只包含一個節點,則條件head->next == head將變為true。 在這種情況下,需要刪除整個連結串列並使頭指標空閒。 這將通過使用以下語句來完成。

if(head->next == head)  
{  
    head = NULL;  
    free(head);  
}

情況3 :(連結串列包含多個節點)

如果連結串列包含多個節點,那麼在這種情況下,需要使用指標ptr遍歷連結串列以到達列表的最後一個節點。 這將通過使用以下語句來完成。

ptr = head;   
while(ptr -> next != head){
    ptr = ptr -> next;
}

在迴圈結束時,指標ptr指向連結串列的最後一個節點。 因為,連結串列的最後一個節點指向連結串列的頭節點。 因此,這將改變為現在,連結串列的最後一個節點將指向頭節點的下一個節點。

ptr->next = head->next;

現在,通過使用C語言中的free()函式釋放頭指標。

free(head);

使節點指向最後一個節點的下一個節點,即連結串列的新頭。

head = ptr->next;

這樣,節點將從一開始就從迴圈單連結串列中刪除。

演算法

第1步:IF HEAD = NULL
  提示記憶體溢位
   轉到第8步
  [IF結束]

第2步:設定PTR = HEAD
第3步:在PTR->NEXT!= HEAD 時重複第4步
第4步:SET PTR = PTR->next
[迴圈結束]

第5步:設定PTR->NEXT = HEAD->NEXT
第6步:免費頭
第7步:SET HEAD = PTR->NEXT
第8步:退出

示意圖

C語言實現程式碼

#include<stdio.h>  
#include<stdlib.h>  
void create(int);
void beg_delete();
struct node
{
    int data;
    struct node *next;
};
struct node *head;
void main()
{
    int choice, item;
    do
    {
        printf("1.Append List\n2.Delete Node from beginning\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:
            beg_delete();
            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");
    }
    else
    {
        ptr->data = item;
        if (head == NULL)
        {
            head = ptr;
            ptr->next = head;
        }else
        {
            temp = head;
            while (temp->next != head)
                temp = temp->next;
            ptr->next = head;
            temp->next = ptr;
            head = ptr;
        }
        printf("Node Inserted\n");
    }

}
void beg_delete()
{
    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;
        while (ptr->next != head)
            ptr = ptr->next;
        ptr->next = head->next;
        free(head);
        head = ptr->next;
        printf("Node Deleted\n");
    }
}

執行上面範例程式碼,得到以下結果 -

1.Append List
2.Delete Node from beginning
3.Exit
4.Enter your choice?1

Enter the item
12

Node Inserted
1.Append List
2.Delete Node from beginning
3.Exit
4.Enter your choice?2

Node Deleted