要刪除迴圈單連結串列中的開頭節點,需要進行一些指標調整。
在開頭有三種從迴圈單連結串列中刪除節點的方案有以下幾種。
如果連結串列為空,則條件head == NULL
將變為true
,在這種情況下,只需要在螢幕上列印下溢並退出。
if(head == NULL)
{
printf("UNDERFLOW\n");
return;
}
如果連結串列只包含一個節點,則條件head->next == head
將變為true
。 在這種情況下,需要刪除整個連結串列並使頭指標空閒。 這將通過使用以下語句來完成。
if(head->next == head)
{
head = NULL;
free(head);
}
如果連結串列包含多個節點,那麼在這種情況下,需要使用指標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