【数据结构】:单链表之头插法和尾插法(动图+图解)

article/2025/9/30 3:46:38

头插法和尾插法

  • 一、头插法
      • 💤思考一:头插法的核心是什么❓
      • ❗❗ 重点一:以带头结点方式实现头插法
      • ❗❗ 重点二:以不带头结点方式实现头插法
  • 二、尾插法
      • 💤思考二:尾插法的核心是什么❓
      • ❗❗ 重点三:以带头结点方式实现尾插法
      • ❗❗ 重点四:以不带头结点方式实现尾插法
  • 三、完整代码
  • 四、运行结果图

请添加图片描述
链表的定义

typedef int ElemType;
typedef struct LNode{ElemType data;           //数据域struct LNode *next;      //指针域
}LNode,*LinkList;

一、头插法

  1. 什么是头插法❓
    在插入时,新的结点插入到当前链表的表头。

  2. 怎么实现头插法❓

    💤思考一:头插法的核心是什么❓

    以有头结点为例:在这里插入图片描述
    只需要将新的节点插在头结点和首元结点之间。所以核心代码为:

    s->next=L->next;		①
    L->next=s;

    注意:①②能否交换顺序❓
    假设可以,那么代码为:② L->next=s; ① s->next=L->next;
    先②后①图:
    在这里插入图片描述
    千万不能交换呦

    ❗❗ 重点一:以带头结点方式实现头插法

    1. 动图:
      在这里插入图片描述
    2. 图解
      在这里插入图片描述
    3. 代码
      LinkList HeadInster(LinkList &L,int n){LNode *s;int x=1;L= (LinkList)malloc(sizeof(LNode));     	//创建头结点L->next=NULL;                               //初始为空链表while(x!=n){s=(LNode*) malloc(sizeof(LNode));   	//创建新结点s->data=x;s->next=L->next;						//核心代码L->next=s;								//核心代码x++;}return L;
      }
      

    ❗❗ 重点二:以不带头结点方式实现头插法

    1. 动图解析
      在这里插入图片描述
    2. 图解
      在这里插入图片描述
    3. 代码
      LinkList Headinster(LinkList &L,int n){LNode *s;int x=1;L= (LinkList)malloc(sizeof(LNode));L->data=x++;L->next=NULL;while(x!=n){s=(LNode*) malloc(sizeof(LNode));s->data=x;s->next=L;L=s;x++;}return L;
      }
      

请添加图片描述

二、尾插法

  1. 什么是尾插法❓
    在插入时,新的结点插入到当前链表的表尾,为此必须增加一个尾指针r,使其始终指向当前链表的尾结点。

  2. 怎么实现头插法❓

    💤思考二:尾插法的核心是什么❓

    以有头结点为例:
    在这里插入图片描述
    由图可知,

    r->next=s;			//①r的指针域指向S(让新结点插入到链表)
    r=s;				//②r指针指向s(保持r指针一直在链表尾端,方便插入新的结点)
    

    那上面两句可以交换吗❓我们来试一试
    在这里插入图片描述
    还是不能交换呦

    ❗❗ 重点三:以带头结点方式实现尾插法

    1. 动图解析
      请添加图片描述
    2. 图解
      在这里插入图片描述
    3. 代码
      LinkList TailInster(LinkList &L,int n){int x=1;L= (LinkList)malloc(sizeof(LNode));LNode *s,*r=L;while(x!=n){s=(LNode*) malloc(sizeof(LNode));s->data=x;r->next=s;r=s;x++;}r->next=NULL;return L;
      }
      

    ❗❗ 重点四:以不带头结点方式实现尾插法

    1. 动图解析
      (略,参考上)
    2. 图解
      在这里插入图片描述
    3. 代码
      LinkList Tailinster(LinkList &L,int n){int x=1;L= (LinkList)malloc(sizeof(LNode));L->data=x++;LNode *s,*r=L;while(x!=n){s=(LNode*) malloc(sizeof(LNode));s->data=x;r->next=s;r=s;x++;}r->next=NULL;return L;
      }
      

三、完整代码

#include "stdio.h"
#include "stdlib.h"typedef int ElemType;
typedef struct LNode{ElemType data;           //数据域struct LNode *next;      //指针域
}LNode,*LinkList;/** 头插法 有头结点*/
LinkList HeadInster(LinkList &L,int n){LNode *s;int x=1;L= (LinkList)malloc(sizeof(LNode));     //创建头结点L->next=NULL;                                //初始为空链表while(x!=n){s=(LNode*) malloc(sizeof(LNode));   //创建新结点s->data=x;s->next=L->next;L->next=s;x++;}return L;
}/** 头插法 无头结点*/
LinkList Headinster(LinkList &L,int n){LNode *s;int x=1;L= (LinkList)malloc(sizeof(LNode));L->data=x++;L->next=NULL;while(x!=n){s=(LNode*) malloc(sizeof(LNode));s->data=x;s->next=L;L=s;x++;}return L;
}/** 尾插法、有结点*/
LinkList TailInster(LinkList &L,int n){int x=1;L= (LinkList)malloc(sizeof(LNode));LNode *s,*r=L;while(x!=n){s=(LNode*) malloc(sizeof(LNode));s->data=x;r->next=s;r=s;x++;}r->next=NULL;return L;
}
/** 尾插法、无结点*/
LinkList Tailinster(LinkList &L,int n){int x=1;L= (LinkList)malloc(sizeof(LNode));L->data=x++;LNode *s,*r=L;while(x!=n){s=(LNode*) malloc(sizeof(LNode));s->data=x;r->next=s;r=s;x++;}r->next=NULL;return L;
}/** 便利链表、头结点*/
void PrintList(LinkList L){LNode *s;s=L->next;while (s!=NULL) {printf("%d\t",s->data);s=s->next;}
}/** 便利链表*/
void Print(LinkList L){LNode *s;s=L;while (s!=NULL) {printf("%d\t",s->data);s=s->next;}
}int main(){LinkList L,S,P,Q;printf("有头结点的头插法:");HeadInster(L,10);PrintList(L);printf("\n无头结点的头插法:");Headinster(P,10);Print(P);printf("\n有头结点的尾插法:");Tailinster(S,10);Print(S);printf("\n无头结点的尾插法:");Tailinster(Q,10);Print(Q);}

四、运行结果图

在这里插入图片描述


http://chatgpt.dhexx.cn/article/YSw1EVP4.shtml

相关文章

链表:头插法与尾插法(简易图解和代码)

头插法 定义:输入的数据次序生成的链表节点次序相反,例如:按1,2,3顺序进行头插之后,最终排序却变成了3,2,1。简而言之就是逆序插入。 定义图解: 代码图解: 代码:(使用头插法建立单…

未声明的标识符

出现未声明的标识符错误,有可能是真的没有声明。但是也有可能是代码中有些注释,格式不对,导致声明的变量的作用域提前结束了。可以把注释都删掉试试

c2065 未声明的标识符 解决ok

场景1: cv::Mat pad_img; cv::Mat img; img 在一个if else后面声明,就报错了 解决方法,把cv::Mat 声明放到前面就行了,原因未知。 场景2: int a3; a为未声明的标识符,加了各种头文件,都不起…

已经包含头文件仍然出现,错误C2065“未声明的标识符”

由于当前在往一个比较大的项目中添加文件,文件又有相似性所以采取了复制的方式,最后出现了一个大疏漏。 在总的.cpp文件中调用新文件中的函数,在包含了新文件的.h头文件的情况下仍然说没有找到标识符,在网上找了很多方法&#xff…

c++: “default”: 未声明的标识符

c: “default”: 未声明的标识符 c: “default”: 未声明的标识符 1、错误描述 2、错误原因: 3、解决方案: 1、错误描述 错误 C2065 “default”: 未声明的标识符 2、错误原因: C11 标准的新特性…

C++命名空间namspace解析——“cout”未声明的标识符,“cin”未声明的标识符

首先我们先看一下下面这段代码运行时的情况&#xff08;注意按ctrlF5 运行&#xff09; #include<iostream> int main() {return 0; }运行结果如下 是一个没有任何结果的窗口 现在我们再加上一段输出代码 cout<<"hello"<<endl;会发现编译运行时…

error C2065: “string”: 未声明的标识符//error C2065: “vector”: 未声明的标识符

添加头文件没&#xff0c; #include <stdio.h> #include <string.h> #include #include using std::vector; #include <stdio.h> #include <string.h> #include <iostream> #include <vector> using std::vector;就这样&#xff0c;先&…

使用控件时提示未声明标识符的解决方法

环境&#xff1a;VS2012&#xff0c;Win8.1 64bit 参考&#xff1a; http://www.cnblogs.com/Romi/archive/2012/01/06/2314390.html http://zhidao.baidu.com/question/256304139.html 1. 用MFC默认创建Dialog类型项目&#xff0c;里面有个VS默认添加的CStatic控件 2. 如果…

引入头文件结构体,解决未声明标识符fileinfo

首先我问大佬&#xff0c;大佬让我右键单击结构体_finddata_t,找下它的定义&#xff0c;但是我没找到啥。然后大佬说让我引入结构体所在的头文件。我就右键单击_finddata_t&#xff0c;联机搜索&#xff0c;找到了它所在的头文件io.h&#xff0c;成功解决了未声明标识符fileinf…

未声明标识符怎么解决oracle,请问 什么是“未声明的标识符”错误,如何解决?...

月关宝盒 它们通常来自忘记包含包含函数声明的头文件&#xff0c;例如&#xff0c;此程序将给出“未声明的标识符”错误&#xff1a;缺少标题int main() { std::cout < return 0;}要修复它&#xff0c;我们必须包含标题&#xff1a;#include int main() { std::cout < re…

vs编译运行报错:未声明的标识符

报错如下图&#xff1a; 很奇怪&#xff0c;我这个testList是已经声明的&#xff0c;就在上一行&#xff0c;但是还是会给我报错&#xff1a;未声明的标识符。 最后发现原因是在报warning的地方。 解决办法&#xff1a; 在代码处右击出现菜单栏&#xff0c;点击最下方的【保存…

未声明标识符怎么解决oracle,什么是“未声明的标识符”错误,如何解决?

潇潇雨雨 它们通常来自忘记包含包含函数声明的头文件&#xff0c;例如&#xff0c;此程序将给出“未声明的标识符”错误&#xff1a;缺少标题int main() { std::cout < return 0;}要修复它&#xff0c;我们必须包含标题&#xff1a;#include int main() { std::cout < re…

插值算法的介绍及其在数学建模中的应用

目录 插值算法的介绍及其在数学建模中的应用 一、插值的介绍及其作用 二、插值法原理 三、插值法的分类 1、普通多项式插值 2、分段低次插值 3、&#xff08;三次&#xff09;样条插值 4、分段三次埃尔米特&#xff08;Hermite&#xff09;插值 插值算法的介绍及其在数…

插值方法学习

0.摘要 我感觉上采样阶段要放在特征提取的前期&#xff0c;而不是后期&#xff0c;因为后期的feature map太小了&#xff0c;而且相邻间的像素值会存在突变&#xff0c;会造成增加的噪声概率会比较高。参考图像插值技术综述学习了一下插值方法 1.单线性插值法 已知ac&#xf…

插值查找算法

插值查找算法 插值查找算法又称插值搜索算法&#xff0c;是在二分查找算法的基础上改进得到的一种查找算法。 插值查找算法只适用于有序序列&#xff0c;换句话说&#xff0c;它只能在升序序列或者降序序列中查找目标元素。作为“改进版”的二分查找算法&#xff0c;当有序序…

图像常用的插值算法:最近邻插值、双线性插值和双三次插值算法

图像常用的插值算法 最近邻插值算法双线性插值算法双三次插值(bicubic)算法三种插值算法的优缺点 插值算法是图像缩放中的一项基本且重要的算法&#xff1b;在图像缩放中&#xff0c;输出图像像素点坐标可能对应输入图像上几个像素点之间的位置&#xff0c;这个时候就需要通过灰…

插值拟合算法

一.插值算法 1.插值概念 构造一个函数使得所有已知点在函数图像上 2.一维插值插值方法 &#xff08;1&#xff09;一般多项式插值 &#xff08;2&#xff09;拉格朗日插值 &#xff08;3&#xff09;分段线性插值 采用线性函数 &#xff08;4&#xff09;牛顿插值 &#xf…

插值与逼近_数值分析计算方法

传送门&#xff1a; 线性和非线性方程数值解法_数值分析计算方法 &#x1f449;插值与逼近_数值分析计算方法 ⚠️施工中&#x1f477;… 1 插值 1.1 多项式插值 1.1.1 Lagrange插值 插值误差的事后估计&#xff1a;用两个结果的差来估计插值误差 使用注意 当插值点x位于…

数学建模-插值算法(Matlab)

注意&#xff1a;代码文件仅供参考&#xff0c;一定不要直接用于自己的数模论文中 国赛对于论文的查重要求非常严格&#xff0c;代码雷同也算作抄袭 如何修改代码避免查重的方法&#xff1a;https://www.bilibili.com/video/av59423231 //清风数学建模 一、基础知识 简单来说…

插值算法总结

1、最邻近元法 这是最简单的一种插值方法&#xff0c;不需要计算&#xff0c;在待求象素的四邻象素中&#xff0c;将距离待求象素最近的邻象素灰度赋给待求象素。设iu, jv(i, j为正整数&#xff0c; u, v为大于零小于1的小数&#xff0c;下同)为待求象素坐标&#xff0c;则待求…