详细解析单链表带头节点的结构体定义,普通单链表与有序单链表的创建等操作(含创建步骤与码源)
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;//返回头结点 代表整个链表
}

相关内容

热门资讯

贷款也“拼团” 银行抢单忙 购物能“拼团”,贷款也能! 近日,一场“拼团融资”的银企对接活动在省工业和信息化厅拉开帷幕。 “贷款...
逛花展、赶市集、嗨直播!202... 5月23日 “2026北京直播电商购物月” 在丰台区丽泽金融商务区·2026北京国际花展 正式拉开帷...
2026中关村毕业季|AI“吃... “上帝会掷骰子吗?” 在联想未来中心的“与智者同场”展区,一位海淀学子对着屏幕问道。 爱因斯坦微微前...
原创 今... 今日为5月23日,国际现货黄金价格在4500美元/盎司整数关口附近徘徊不前,日内最低触及4480美元...
三连亏后变为“无主”状态,农尚... 从吴亮手中接盘农尚环境(300536)不足三年后,林峰如今让出了公司控制权,上市公司进入“无主”状态...
55岁湖南女首富出手!豪掷13... 快科技5月24日消息,与马斯克、库克并肩而坐,刚参加完国宴的湖南女首富周群飞就买了家上市企业。 近日...
外资加仓A股,岂是跟风这么简单... 熬过忙碌的交易日,在周末安静时段,理清接下来布局方向。本篇为大家准备了5条要闻,涵盖市场动态、行业变...
原创 俄... 在全球能源的残酷牌桌上,手里攥着石油,腰杆子才能硬气。长期以来,中东的沙漠、俄罗斯的冰原、美国的页岩...
喜力啤酒有产品将涨价,华润啤酒... 来源:红星新闻 红星资本局5月22日消息,今日,红星资本局从雪花啤酒(厦门)有限公司、华润啤酒方面获...
原创 金... 心理预期调整刻不容缓,五月二十二日,黄金价格或将重现十五年前的历史性低迷。 近期若您密切关注着黄金市...
原创 马... 埃隆·马斯克如果能让SpaceX实现“科幻小说”级别的目标,他可能获得1万亿美元的收入。 埃隆·马斯...
涨涨涨!放开限制、可加杠杆!这... 韩国股市站在风口上! 据最新消息,为吸引更多海外资金进入股市,韩国政府计划放开限制,允许境外投资者直...
下周9家上会丨科创板首单IPO... IPO及再融资上会预告 据交易所官网审核动态信息,下周(5.25-5.29)IPO上会审核6家企业,...
富途、老虎市值蒸发1/4!或被... 来源:金融时报 5月22日,中国证监会宣布依法对Tiger Brokers (NZ) Limited...
马爸爸的好兄弟钱多多搞了杀猪盘... *此图由AI生成 作者| 史大郎&猫哥 来源| 是史大郎&大猫财经Pro 上周四,港股经纬天地大崩盘...
原创 壳... 编辑:XL 国际能源圈最近炸开了锅,壳牌这家百年石油巨头在2026年3月与委内瑞拉政府正式签署多项油...
存储热潮愈演愈烈!奖金拿到手软... 财联社5月24日讯(编辑 卞纯)在席卷全球的存储芯片热潮中,韩国“存储芯片双雄”SK海力士和三星无疑...
揽牌、合作、生态,跨境支付头部... 近日,国内头部跨境支付机构密集落地海外重要布局,一方面,连连数字、PingPong两家公司相继在中东...
原创 帮... 老铁们,周末好!我是帮主郑重。刚扫了一眼下周的财经日历,好家伙,事件一个接一个,堪称“消息面轰炸周”...
海南省住建厅与中国石化海南石油... 5月22日,中国石化海南石油分公司代表、党委书记李新强、总经理蔡文东一行赴海南省住建厅拜访交流。省住...