24.8.1数据结构|单链表

主要部分:

1、定义:定义带链表的结构体,数据域和指针域

2、初始化:创建一个含有N个元素的带头结点的单链表head

申请空间,给链表赋值

3、求表长:返回head的长度(遍历)

4、取元素:取出单链表head的第I个元素的值

(遍历。首先确定I的取值范围,再从单链表的第一个节点开始顺序逐个往后搜索直到找到第二个节点,将该节点元素值带回)

5、**定位:**查找元素X在单链表head中第一次出现的位置【返回一个i】

遍历

6**、删除:**删除在头节点head的第i个节点

借助辅助指针P,Q。

7、**插入:**在带头结点的单链表head的第i个结点之前插入一个值为X的新结点

借助辅助指针P,Q。先处理新节点,后处理老节点。

8、输出:输出带头结点的单链表态的中的所有节点值

课本要求掌握以上7个函数的代码

//失败返回0,成功返回1.

头结点的数据域一般不存放任何信息也可用来存储一些附加信息如链表的长度等

代码刚刚敲完就卡了,然后就没了,我真的会谢。。。

例题:

1、编写算法实现两个带头结点单向链表a和B的连接要求结果链表仍使用原来两个链表的存储空间不另开辟存储空间。

2、将两个带头结点的非递减有序单向链表la和LB归并成一个非递减的有序单链表要求结果链表仍使用原来两个链表的存储空间不另开辟存储空间表中允许有重复的数据

3、用带头结点单向链表实现集合操作a并B要求结果链表仍使用原来两个链表的存储空间不另开辟存储空间

4、编写算法实现带头结点单链表head逆置要求结果链表仍使用原链表的存储空间不不另开辟存储空间

5、将带头结点单链表head拆分成一个奇数链表和一个偶数链表要求结果链表仍使用原来链表的存储空间不另开辟存储空间

相关推荐
浅念-4 小时前
刷穿LeetCode:BFS 解决 Flood Fill 算法
数据结构·c++·算法·leetcode·职场和发展·bfs·宽度优先
im_AMBER7 小时前
手撕hot100之矩阵!看完这篇就AC~
javascript·数据结构·线性代数·算法·leetcode·矩阵
如君愿7 小时前
考研复习 Day 30 | 习题--计算机网络 第五章(运输层 上)、数据结构 图(上)
数据结构·计算机网络·课后习题
weixin_421725267 小时前
C语言中volatile关键字怎么用C语言volatile在多线程中的作用
c语言·数据结构·运算符优先级·变量命名·volatile关键字
05候补工程师9 小时前
【408 从零到一】线性表逻辑特征、存储结构对比与 C/C++ 动态内存分配避坑指南
c语言·开发语言·数据结构·c++·考研
努力努力再努力wz9 小时前
【MySQL 进阶系列】拒绝滥用root:从 mysql.user 到权限校验,带你彻底理解用户管理与授权机制!
android·c语言·开发语言·数据结构·数据库·c++·mysql
炸膛坦客10 小时前
嵌入式 - 数据结构与算法:(1-4)数据结构 - 单链表的两个核心缺点(引入循环/双向链表)
c语言·数据结构·链表
Hesionberger11 小时前
LeetCode 78:子集生成全攻略
java·开发语言·数据结构·python·算法·leetcode·职场和发展
上弦月-编程12 小时前
高效编程利器:转移表技术解析
c语言·开发语言·数据结构·算法·排序算法
薇茗12 小时前
【初阶数据结构】 左右逢源的分支诗律 二叉树2
c语言·数据结构·算法·二叉树