详细解析单链表带头节点的结构体定义,普通单链表与有序单链表的创建等操作(含创建步骤与码源)
admin
2024-03-30 13:47:29
0

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 1list->last->next = pnew;list->last = pnew;#endif//头插#if 0pnew->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;//返回头结点 代表整个链表
}

相关内容

热门资讯

【美联储理事警告:美联储货币政... 【美联储理事警告:美联储货币政策可能无法应对AI引发的失业潮 】库克称,AI已引发美国劳动力市场的代...
黄金和交易提醒:金价高位“吞没... 来源:市场资讯 文章来源:汇通财经 周三(2月26日)亚市早盘,现货黄金窄幅震荡,目前交投于5150...
IPO雷达| 百普赛斯港股IP... 百普赛斯(301080.SZ)正式向香港联交所递交招股书。根据公司同步发布的2025年度业绩预告,全...
原创 澳... 2025年一则“澳洲高薪挖角中国稀土团队”的新闻,把全球稀土市场搅得风生水起。澳大利亚莱纳斯公司甩出...
苹果收购单人AI初创公司inv... IT之家 2 月 25 日消息,据 MacRumors 报道,一份提交给欧盟的新文件显示,苹果公司已...
珍惜:由早晨跑步所想到的 我每天早晨起来习惯在校园跑步,在跑步的时候,常常会思考跑步、人生及享受人生之间的关系。 我们知道人的...
趁乱抛售?最高法院刚裁决,对冲... 来源:市场资讯 来源:金十数据 根据外媒获得的一份美国银行报告,花旗的对冲基金客户在上周五美国最高法...
特别关注|9艘!“超高规格”新... 根据广船国际官微介绍,上述MR型油轮新造船为广船国际自主设计,总长约183米、宽32.2米,设计服务...
甲骨文股价在星门项目相关报道发... 来源:环球市场播报 周一, 甲骨文股价下跌4.5%,此前报道称,这家云计算公司与OpenAI和软银的...
氨氯地平阿托伐他汀钙片用药推荐 在中国,高血压与高血脂常常结伴而行,据数据显示,不少高血压患者同时合并血脂异常。这两种疾病叠加,会让...
中国资产大涨!苹果市值一夜增超... 当地时间2月24日,美股三大指数集体收涨,纳指涨1.04%,标普500指数涨0.77%,道指涨0.7...
上节育环后需要注意什么 一、休息与活动 上节育环后要适当休息,避免剧烈运动和重体力劳动,一般建议休息1 - 2天。因为过早进...
挖矿收益不足3美分!比特币暴跌... 来源:环球市场播报 TMG Core 展台的液体浸没式冷却矿槽中的加密货币矿机。 罗森布拉特证券公...
众机构唱多三星电子:存储巨头冲... 财联社2月25日讯(编辑 史正丞)随着三星电子周二收涨3.6%,迈上每股20万韩元的历史新高,分析师...
增值税发票数据显示:春节假期消... 新华社北京2月24日电(记者刘开雄)记者2月24日从国家税务总局获悉,增值税发票数据显示,2026年...
从“向外求索”到“向内安顿”的... 从“向外求索”到“向内安顿”的消费觉醒 当商务宴席上的茅台与书房中静静摆放的谦夫子养生露酒同时出现在...
千寻智能完成近20亿元融资 北京商报讯(记者 陶凤 王天逸)2月24日,具身智能头部企业千寻智能宣布,近日连续完成两轮融资,金额...
原创 银... 最近不少人发现,家附近的银行网点悄悄关门了,有的贴出公告终止营业,有的直接撤柜清空,就连工商银行、建...
美联储理事库克称央行可能无法应... 来源:环球市场播报 美联储理事丽莎·库克警告称,美国央行可能无法应对因采用人工智能而导致的失业率上升...