美文网首页
5.4. 删除循环单链表末尾元素

5.4. 删除循环单链表末尾元素

作者: 易百教程 | 来源:发表于2018-11-14 09:28 被阅读12次

在循环单链表中删除末尾节点有三种情况。

情况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(链表包含多个元素)

如果链表中有多个节点,那么要删除最后一个节点,需要到达最后一个节点。 还需要跟踪链表的倒数第二个节点。 为此,需要定义两个指针ptrpreptr。 以下代码序列用于此目的。

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

现在,需要再做一次指针调整。需要将指针指向pretrnext指向ptrnext(即head),然后使指针ptr空闲(释放)。

preptr->next = ptr -> next;  
free(ptr);  

算法

第1步:IF HEAD = NULL
   提示 “内存溢出”
    转到第8步
   [IF结束]

第2步:设置PTR = HEAD
第3步:重复第4步和第5步,同时PTR - > NEXT!= HEAD
第4步:SET PREPTR = PTR
第5步:SET PTR = PTR - > NEXT
[循环结束]

第6步:设置PREPTR - > NEXT = HEAD
第7步:释放PTR
第8步:退出

示意图

image

C语言实现示例代码 -

#include<stdio.h>  
#include<stdlib.h>  
void create(int);
void last_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 end\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:
            last_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\n");
    }
    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 last_delete()
{
    struct node *ptr, *preptr;
    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)
        {
            preptr = ptr;
            ptr = ptr->next;
        }
        preptr->next = ptr->next;
        free(ptr);
        printf("Node Deleted\n");
    }
}

执行上面示例代码,得到以下结果 -

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

Enter the item
90

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

Node Deleted

相关文章

  • 5.4. 删除循环单链表末尾元素

    在循环单链表中删除末尾节点有三种情况。 情况1(链表为空) 如果链表为空,则条件head == NULL将变为tr...

  • 链表

    链表 缺点:查找复杂有点:定点删除/插入元素 单链表 双向链表 循环链表 双向循环链表 数组与链表的区别 数据存储...

  • 单链表和双链表

    单链表(可以用来实现栈和队列) 删除链表的元素 添加元素 双向链表(实现LinkedList) 添加元素 删除元素

  • 双向循环链表

    双向循环链表 初始化 添加元素 删除元素 输出整个链表 实现代码 尚未实现 bclist_free删除链表所有元素

  • 0x05双向循环链表

    1 双向循环链表创建 2 双向循环链表插入元素 3 遍历双向循环链表 4双向循环链表删除结点

  • 链表

    单链表的添加和删除元素

  • 数据结构基础--单向循环链表

    单向循环链表 单向循环链表是可循环的单链表,它与单链表的区别在于单向链表的最后一个元素的指针域为空,而单向循环链表...

  • 单链表反转

    单链表反转 单链表初始化 输出 反转 释放 实现代码 尚未实现 元素插入 元素删除

  • [数据结构]第二章线性表(5)——循环链表

    循环链表 循环单链表 具体实现: 优势: 循环双链表 初始化 插入 删除 总结反思 源码 源码查看地址,点击 传送...

  • 线性表元素插入和删除

    单链表(链式存储结构)插入 单链表(链式存储结构)删除 有头结点的单链表在开始结点前插入元素等同在头结点后插入元素...

网友评论

      本文标题:5.4. 删除循环单链表末尾元素

      本文链接:https://www.haomeiwen.com/subject/sdrdfqtx.html