数据结构和算法学习记录——线性表之单链表(上)-初始单链表及其尾插函数(顺序表缺陷、单链表优点、链表打印)

简介: 数据结构和算法学习记录——线性表之单链表(上)-初始单链表及其尾插函数(顺序表缺陷、单链表优点、链表打印)

单链表的概念

单链表是一种链式存取的数据结构,链表中的数据是以结点来表示的。

每个结点的构成:元素(数据元素的映象) + 指针(指示后继元素存储位置)。

元素就是存储数据的存储单元,指针就是连接每个结点的地址数据。

以“结点的序列”表示的线性表称作线性链表(单链表),单链表是链式存取的结构。


复习一下之前学过的顺序表:

顺序表的缺陷

1.当空间不够时需要增容,而增容需要付出代价,浪费一些空间。

2.为了避免频繁增容,一般地,增容时都增至原本容量的2倍;这样就会可能存在一部分空间没有被使用的情况。

3.顺序表的数据是从开始的位置连续存储的,当需要从头部或者中间插入或删除数据时,就需要挪动数据,效率不高。


顺序表的优势

1.支持随机访问。

(有些算法需要结构支持随机访问,比如:二分查找、优化的快速排序等等)

而链表呢

链表的优势.1.按需申请空间,不用了就释放空间(更合理地使用空间)。 2.在头部或中间插入或删除数据时,不需要挪动数据,效率较高。


链表的缺陷

1.每一个数据,都要存一个指针去链接后面的数据结点。

2.不支持随机访问。

单链表的结构

逻辑结构

想象出来的、便于理解的

物理结构

内存中实际如何存储的

代码呈现

//单链表的基本结构
#define SLTDataType int
typedef struct SListNode
{
    SLTDataType data;
    struct SListNode * next;
}SLTNode;

单链表的打印

//单链表的打印
void SListPrint(SLTNode* phead)
{  //创建一个临时结点,将phead赋给cur
  SLTNode* cur = phead;
  
  //判断cur是否等于空
   while(cur != NULL)
   {
     //打印链表数据
     printf("%d->",cur->data);
     
     //找下一块的数据,就要找下一个结点
     //而下一个结点存放于cur中,通过cur找到下一个结点
     //一直循环,直到next指针指向NULL时,链表打印完成
     cur = cur->next;
   }
}

单链表的尾插函数

要实现单链表尾插,首先判断传入的链表是否为空,如果为空,则直接给其赋值。

如果不为空,则需要找到最后一个结点,即尾结点。尾结点的特征是:next指针指向NULL。

通过这一特征找到尾结点,再将新结点赋给尾结点。同时新结点的next指针指向NULL。

//单链表尾插函数
void SListPushBack(SLTNode ** pphead,SLTDataType x)
{  //创建一个新结点
   SLTNode * newnode = (SLTNode *)malloc(sizeof(SLTNode));
   newnode->data = x;
   newnode->next = NULL;
  //当传入的链表为空时,要先给其赋值,才能进行后面的操作
  //二级指针pphead存储着一级指针变量phead的地址,解引用一次得到phead的地址
   if(*pphead == NULL)
   {
       *pphead = newnode; //将新结点赋给头结点
   }
   else
   {
       //要进行尾插,就要先找到尾结点
       //尾结点的特征:next指针为空指针
       //建立一个新结点,命名为尾结点
       SLTNode * tail = *pphead;
       while(tail->next != NULL)//遍历找到尾结点
       {
           tail = tail->next;
       }
       tail->next = newnode;
   }
}


线性表之单链表(下)

目录
相关文章
|
5月前
|
机器学习/深度学习 算法 数据挖掘
没发论文的注意啦!重磅更新!GWO-BP-AdaBoost预测!灰狼优化、人工神经网络与AdaBoost集成学习算法预测研究(Matlab代码实现)
没发论文的注意啦!重磅更新!GWO-BP-AdaBoost预测!灰狼优化、人工神经网络与AdaBoost集成学习算法预测研究(Matlab代码实现)
201 0
|
4月前
|
机器学习/深度学习 运维 算法
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
【微电网多目标优化调度】多目标学习者行为优化算法MOLPB求解微电网多目标优化调度研究(Matlab代码实现)
271 1
|
10月前
|
算法 数据可视化 开发者
为什么要学习数据结构与算法
今天,我向大家介绍一门非常重要的课程——《数据结构与算法》。这门课不仅是计算机学科的核心,更是每一位开发者从“小白”迈向“高手”的必经之路。
为什么要学习数据结构与算法
|
11月前
|
存储 算法 Java
算法系列之递归反转单链表
递归反转链表的基本思路是将当前节点的next指针指向前一个节点,然后递归地对下一个节点进行同样的操作。递归的核心思想是将问题分解为更小的子问题,直到达到基本情况(通常是链表末尾)。
376 5
算法系列之递归反转单链表
|
负载均衡 算法
架构学习:7种负载均衡算法策略
四层负载均衡包括数据链路层、网络层和应用层负载均衡。数据链路层通过修改MAC地址转发帧;网络层通过改变IP地址实现数据包转发;应用层有多种策略,如轮循、权重轮循、随机、权重随机、一致性哈希、响应速度和最少连接数均衡,确保请求合理分配到服务器,提升性能与稳定性。
2564 11
架构学习:7种负载均衡算法策略
|
存储 算法 测试技术
【C++数据结构——线性表】求集合的并、交和差运算(头歌实践教学平台习题)【合集】
本任务要求编写程序求两个集合的并集、交集和差集。主要内容包括: 1. **单链表表示集合**:使用单链表存储集合元素,确保元素唯一且无序。 2. **求并集**:遍历两个集合,将所有不同元素加入新链表。 3. **求交集**:遍历集合A,检查元素是否在集合B中存在,若存在则加入结果链表。 4. **求差集**:遍历集合A,检查元素是否不在集合B中,若满足条件则加入结果链表。 通过C++代码实现上述操作,并提供测试用例验证结果。测试输入为两个集合的元素,输出为有序集合A、B,以及它们的并集、交集和差集。 示例测试输入: ``` a c e f a b d e h i ``` 预期输出:
383 7
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】单链表的基本运算(头歌实践教学平台习题)【合集】
本内容介绍了单链表的基本运算任务,涵盖线性表的基本概念、初始化、销毁、判定是否为空表、求长度、输出、求元素值、按元素值查找、插入和删除数据元素等操作。通过C++代码示例详细解释了顺序表和链表的实现方法,并提供了测试说明、通 - **任务描述**:实现单链表的基本运算。 - **相关知识**:包括线性表的概念、初始化、销毁、判断空表、求长度、输出、求元素值、查找、插入和删除等操作。 - **测试说明**:平台会对你编写的代码进行测试,提供测试输入和预期输出。 - **通关代码**:给出了完整的C++代码实现。 - **测试结果**:展示了测试通过后的预期输出结果。 开始你的任务吧,祝你成功!
578 5
|
机器学习/深度学习 存储 C++
【C++数据结构——线性表】顺序表的基本运算(头歌实践教学平台习题)【合集】
本文档介绍了线性表的基本运算任务,涵盖顺序表和链表的初始化、销毁、判定是否为空、求长度、输出、查找元素、插入和删除元素等内容。通过C++代码示例详细展示了每一步骤的具体实现方法,并提供了测试说明和通关代码。 主要内容包括: - **任务描述**:实现顺序表的基本运算。 - **相关知识**:介绍线性表的基本概念及操作,如初始化、销毁、判定是否为空表等。 - **具体操作**:详述顺序表和链表的初始化、求长度、输出、查找、插入和删除元素的方法,并附有代码示例。 - **测试说明**:提供测试输入和预期输出,确保代码正确性。 - **通关代码**:给出完整的C++代码实现,帮助完成任务。 文档
411 5
|
机器学习/深度学习 人工智能 自然语言处理
【EMNLP2024】基于多轮课程学习的大语言模型蒸馏算法 TAPIR
阿里云人工智能平台 PAI 与复旦大学王鹏教授团队合作,在自然语言处理顶级会议 EMNLP 2024 上发表论文《Distilling Instruction-following Abilities of Large Language Models with Task-aware Curriculum Planning》。