详细解析单链表带头节点的结构体定义,普通单链表与有序单链表的创建等操作(含创建步骤与码源)

14天阅读挑战赛
努力是为了不平庸~
算法学习有些时候是枯燥的,这一次,让我们先人一步,趣学算法!欢迎记录下你的那些努力时刻(算法学习知识点/算法题解/遇到的算法bug/等等),在分享的同时加深对于算法的理解,同时吸收他人的奇思妙想,一起见证技术er的成长~

目录

单链表回顾

带头结点的单链表

带头节点的意义

什么是头节点

头节点与数据节点定义

创建带头节点的单链表的步骤与详细代码

创建有序带头节点单链表的步骤与码源


单链表回顾

如果对普通单链表又需求,可到博主主页搜索“大厂面试经典单链表例题”即可。

带头结点的单链表

带头节点的意义

很多时候我们可能经常需要知道一个链表有多少个结点,或者求一个链表的最后一个结点...
        => 我们都要通过第一个结点的指针,遍历整个链表。

而一个头节点就能很好的帮我们解决这个问题,而且只需要知道单链表的第一个结点的指针,first  对单链表的基本操作 “增删改查”就可以完成了

例如:

find_x
p = h;
while(p)
{
	if(p->data == x)
	{
	    break;
	}
	p = p->next;
}
		
find_last
p = h;
while(p)
{
    if(p->next == NULL)
	{
		reak;
	}
	p = p->next;
}

什么是头节点

    头结点是用来管理链表的结点,这个结点一般包括常用的管理链表的数据对象:
    eq: 指向链表的第一个结点指针 ,指向链表最后一个结点的指针...
    
    什么是数据结点?
        原来用来保存数据的结点 就称为数据结点
        
    头结点是唯一一个标识一个链表存在与否的标志。
    
    带头结点的单链表:
        一个链表可以没有数据结点,但是必须要有头结点。
        
        没有数据结点,表示“空链表”
        没有头结点,表明这个链表不存在

头节点与数据节点定义

提示:简单描述算法知识点相关题目题意

//数据结点:
typedef int ElemType;
typedef struct node
{
	ElemType data;//数据域
	struct node *next;//指针域
}Node;

//头结点:不保存数据 只有两个指针 加一个结点数目
typedef struct linkedlist
{
	Node *first;//指向链表中的第一个数据结点
	Node *last;//指向链表中的最后一个数据结点
	ElemType NodeNum;//结点的数目
	//...//根据具体需求 增加其它的成员变量
}List;

创建带头节点的单链表的步骤与详细代码

根据用户的输入数据 创建一个单链表
    step1:创建一个头结点
    step2:每获得一个数据就创建一个数据结点
    step3:把获得的数据 写入到数据结点中
    step4:把数据结点加入到链表中去。

List *create_list()
{
    ElemType d;//用来保存获取的数据
    Node *pnew = NULL;//指向新创建的数据结点
    //step1:创建一个头结点
    List *list = malloc(sizeof(*list));
    list->first = NULL;
    list->last = NULL;
    list->NodeNum = 0;

    //step2 :每获得一个数据就创建一个数据结点
    while(1)
    {
        scanf("%d",&d);
        if(d == 0)
        {
            break;
        }
        pnew = malloc(sizeof(*pnew));

    //step3:把获得的数据 写入到数据结点中
        pnew->data = d;
        pnew->next = NULL;

    //step4:把数据结点加入到链表中去。
        if(list->first == NULL)//从无都有
        {
            list->first = pnew;
            list->last = pnew;
        }
        else//从少到多
        {
            //尾插
            #if 1
            list->last->next = pnew;
            list->last = pnew;
            #endif
            //头插
            #if 0
            pnew->next = list->first;
            list->first = pnew;
            #endif
        }
        list->NodeNum++;
    }
    return list;
}

创建有序带头节点单链表的步骤与码源

    创建一条带头结点的有序列表  升序
        step1:创建一个头结点
        step2:每获得一个数据就创建一个数据结点
        step3:把获得的数据 写入到数据结点中
        step4:把数据结点加入到链表中去。
                从无到有
                从少到多 --》找到第一个比pnew大的数据
                    1.第一个就比pnew大 pnew头插
                    2.找一了遍 没有找

/*
    create_sort_list:创建一条带头结点的有序单链表
    返回值:
        创建好的单链表的头结点
*/
List *create_sort_list()
{
    ElemType d;//用来保存获取的数据
    Node *pnew= NULL;//指向新创建的数据结点
    //step1:创建一个头结点
    List *list = malloc(sizeof(*list));
    list->first = NULL;
    list->last = NULL;
    list->NodeNum = 0;

    while(1)
    {

        //step2:每获得一个数据就创建一个数据结点
        scanf("%d",&d);
        if(d == 0)
        {
            break;
        }
        pnew = malloc(sizeof(*pnew));

        //step3:把获得的数据 写入到数据结点中
        pnew->data = d;
        pnew->next = NULL;

        //step4:把数据结点加入到链表中去。
        if(list->first == NULL)//从无到有
        {
            list->first = pnew;
            list->last = pnew;

        }

        else//从少到多
        {
            Node *p = list->first;//遍历指针 要找到第一个比pnew大的值
            Node *pre = NULL;//指向p前面的那个结点
            while(p)
            {
                if(p->data > pnew->data)//找到了
                {
                    break;
                }
                pre = p;
                p = p->next;
            }
            if(p != NULL)
            {
                if(p == list->first)//头插 第一个数就比我的Pnew大
                {
                    pnew->next = list->first;
                    list->first = pnew;
                }
                else
                {
                    pre->next = pnew;
                    pnew->next = p;
                }

            }
            else//p为null pnew最大
            {
                //pre->next = pnew;
                list->last->next = pnew;
                list->last = pnew;
            }
        }
        list->NodeNum++;
    }
    return list;//返回头结点 代表整个链表
}

  • 19
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 13
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

勾栏听曲_0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值