单链表介绍及其实现

链表

文章目录

  • 链表
      • 链表的专业术语:
      • 实现

链表的专业术语:

  1. 首节点:存放第一个有效数据的结点;
  2. 尾结点:存放最后一个有效数据的结点;尾指针指向;
  3. 头结点:头结点的数据类型和首结点的类型一模一样;

头结点是首节点前面的那个结点;
头结点并不存放有效数据;
设置头结点的目的是为了方便存储数据;

  1. 头指针:存放头结点地址的指针变量,指向头结点;

单链表的插入实现逻辑:
在这里插入图片描述
链表插入的核心语句:

Step 1:s->next=p->next;
Step 2:p->next=s ;

单链表的删除实现逻辑:
在这里插入图片描述
删除动作的核心语句(要借助辅助指针变量q):

q = p->next;           //首先保存b的指针,靠它才能找到c;
p->next=q->next;      //将a、c两结点相连,淘汰b结点;
free(q)//彻底释放b结点空间

实现

  1. 以下代码实现了链表的插入,删除,反转,遍历
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#define MAXSIZE (10)typedef int ElementType;
typedef struct Node {ElementType data;struct Node *Next;
} *List;List CreateList(void)       //建表,初始化为空 
{List L = (List)malloc(sizeof(struct Node));if (L == NULL) {printf("Out of space!");return NULL;}L->data = 0;L->Next = NULL;return L;
}List InitList(List L)    //初始化链表 
{List rear = L;srand((unsigned)time(NULL));for (int i = 0; i < MAXSIZE; i++) {List p = (List)malloc(sizeof(struct Node));p->data = rand() % 100;  //生成10个随机数,范围0~100 rear->Next = p;rear = p;	}rear->Next = NULL;
}void PrintList(List L)  //遍历 
{List head = L->Next;while (head) {printf("%d ", head->data);head = head->Next;}printf("\n");
}void ReverseList(List L)  //反转 
{List head = L->Next;List tmp = L->Next->Next;head->Next = NULL;List p = NULL;while (tmp) {p = tmp;tmp = tmp->Next;p->Next = head;head = p;}L->Next = head;
}void DeleteEven(List L)  //删除 
{List p = L;List q;while (p->Next) {q = p->Next;if (q->data % 2 == 0) {p->Next = q->Next;free(q);   //删除里面所有的偶数 } else {p = p->Next;}}
}void Insert(List L)  //插入 
{int input;List p = L;List q = L->Next;List tmp = (List)malloc(sizeof(struct Node));printf("please input specify number to insert: ");scanf("%d", &input);tmp->data = input;while (q && (q->data < input)) {p = p->Next;q = p->Next;   //将输入的数据按大小插入链表 }tmp->Next = q;p->Next = tmp;
}int main(void)
{List L = CreateList();InitList(L);PrintList(L);ReverseList(L);PrintList(L);DeleteEven(L);PrintList(L);Insert(L);PrintList(L);return 0;
}
  1. 运行结果如图
    在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/482296.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux基础概念及常用命令

Linux基础概念及常用命令 文章目录Linux基础概念及常用命令1 Linux概述1.1 为什么要学Linux1.2 Linux简介1.3 Linux 发行版1.4 Linux 应用领域2 Linux常用命令2.1 Linux目录结构2.2 Linux目录命令2.3 Linux文件命令2.4 Linux其他命令1 Linux概述 1.1 为什么要学Linux linux诞生…

PNAS新研究:剑桥学者发现,有些 AI 模型无法被计算

来源&#xff1a;AI科技评论作者&#xff1a;Ailleurs编辑&#xff1a;陈彩娴近日&#xff0c;剑桥学者在《美国科学院院报》&#xff08;PNAS&#xff09;上发表了一篇名为“The Difficulty of Computing Stable and Accurate Neural Networks: On the Barriers of Deep Learn…

量子计算机首次成功模拟化学反应

SHUTTERSTOCK来源&#xff1a;IEEE电气电子工程师━━━━利用谷歌的Sycamore量子处理器&#xff0c;科学家们进行了迄今为止涉及量子计算机的最大规模的化学模拟。他们采用了一种新技术&#xff0c;可能有助于抵抗量子电路中常见的噪声。量子计算机理论上可以实现量子优势&…

单链表的按位置插入和删除

单链表的插入和删除 文章目录单链表的插入和删除1 单链表插入2 单链表删除3 代码实现1 单链表插入 要想将结点s插入到ai与ai1之间&#xff0c;不需要移动数据元素&#xff0c;只需要在ai与ai1之间插入一个新的结点&#xff0c;也就是我们要插入的结点s。关键就是要修改结点p的…

DeepMind最新研究:如何将「大语言模型」 训练到最优?

来源&#xff1a;AI科技评论 作者&#xff1a;维克多Transformer的提出距离我们已经有5年的时间&#xff0c;随着模型规模的不断增长&#xff0c;性能提升也逐渐出现边际效益递减的情况。如何训练出最优性能的大模型&#xff1f;最近&#xff0c;DeepMind做了一项调查&#xf…

给计算机处理器做手术来研究大脑

来源&#xff1a;混沌巡洋舰在人类对大脑认识的历史上&#xff0c;曾经使用过很多隐喻来描述脑&#xff0c;比如齿轮机械、电话交换机、计算机等等。目前&#xff0c;“脑就像一台计算机”这个隐喻仍然占据着主导地位&#xff0c;尽管人们对于这个隐喻的贴切程度的看法存在分歧…

为什么百度查到的ip地址和ipconfig查到的不同;详解公网Ip和私网ip; 网络分类ABC类;

文章目录1.百度查到的ip和ipconfig查到的不同1.1引出问题1.2不一样的原因2.IP地址分类2.1IP类别2.1 Public IP和Private IP3.总结3.1整理上网流程3.2遗留问题1.百度查到的ip和ipconfig查到的不同 IP可以分为Public IP 和 Private IP,出现这种规划的原因在于IPv4所能表示的IP太少…

国科金:共融机器人基础理论与关键技术研究重大研究计划

来源&#xff1a;学术头条国家自然科学基金委员会现发布共融机器人基础理论与关键技术研究重大研究计划 2022 年度项目指南&#xff0c;请申请人及依托单位按项目指南中所述的要求和注意事项申请。 国家自然科学基金委员会 2022 年 4 月 2 日一、科学目标本重大研究计划瞄准国…

停止追赶最新的 RPA 趋势

来源&#xff1a;AI前线作者&#xff1a;Anupam Krishnamurthy译者&#xff1a;Phoenix策划&#xff1a;蔡芳芳本文最初发布于 anupam.de 博客&#xff0c;由 InfoQ 中文站翻译并分享。我做了 4 年的 RPA 开发者——2017 至 2021 年。在 2019 年底&#xff0c;我做了一个重要的…

请求转发与重定向的区别和执行流程

请求转发与重定向的区别和执行流程 文章目录请求转发与重定向的区别和执行流程1 请求转发与重定向区别2 现实生活的例子2.1 重定向2.2 请求转发3 重定向-流程图、代码、结果3.1 流程图3.2 代码BoyServlet3.3 代码GirlServlet3.4 web.xml文件3.5 结果4 请求转发-流程图、代码、结…

牛津大学最新调研:AI面临基准危机,NLP集中“攻关”推理测试

来源&#xff1a;AI科技评论作者:维克多人工智能&#xff08;AI&#xff09;基准为模型提供了衡量和比较的路径&#xff0c;超越基准&#xff0c;达到SOTA&#xff0c;经常成为顶会论文的标配。同时&#xff0c;有些基准确实推动了AI的发展&#xff0c;例如ImageNet 基准测试对…

Postman使用小教程--基础入门篇

文章目录1 Postman介绍2 postman基础功能介绍2.1 postman基础页面2.2 postman基础页面介绍2.2 接口测试流程和原理2.3 请求区域介绍3 导出和导入接口集3.1 导出3.2 导入4 设置环境变量4.1 环境变量优先级4.2 新建环境变量4.3 将返回值的某个数据设置为环境变量4.4 将其他的常用…

W玻色子质量实验与理论矛盾,或是十年来最重要的进展

来源&#xff1a;科学大院就在昨天&#xff0c;美国费米实验室的CDF项目在《Science》上发了篇文章&#xff0c;W玻色子质量的测量结果和标准模型预测的结果有明显差距。消息一出&#xff0c;粒子物理界炸了窝。因为这或许是十年来最重要的粒子物理进展&#xff01;这个结果意味…

Git理论教程

文章目录1 什么是Git1.1 什么是版本控制系统1.2 为什么需要版本控制系统1.3 常见的版本控制工具1.4 版本控制分类1.4.1 集中版本控制 SVN1.4.2 分布式版本控制 Git1.4.3 Git与SVN的主要区别2 Git环境配置3 Git基本理论3.1 Git三个区域3.2 Git工作流程3.3 Git项目搭建3.3.1 本地…

Science | 再创生命奇迹!日本科学家造出了不需要“父亲”的大鼠及小鼠

来源&#xff1a;【iNature】iNature从多能干细胞 (PSC) 体外生成生殖细胞可以对未来的生殖医学和动物育种产生重大影响。十年前&#xff0c;在小鼠中建立了体外配子发生。然而&#xff0c;在任何其他物种中尚未实现诱导原始生殖细胞样细胞&#xff08;PGCLCs&#xff09;产生配…

总结Vue中index.html、main.js、App.vue、index.js之间关系以及Vue项目加载流程

总结Vue中index.html、main.js、App.vue、index.js之间关系以及Vue项目加载流程 文章目录总结Vue中index.html、main.js、App.vue、index.js之间关系以及Vue项目加载流程1 vue中index.html、main.js、App.vue、index.js关系简介1.1 项目的运行入口index.html1.2 入口文件main.j…

ACM 杰出会员姬水旺:量子化学和物理的深度学习

整理&#xff1a;汪浩文校对&#xff1a;维克多量子技术和人工智能都是当前最先进的科学技术&#xff0c;前者被寄希望于拥有超强的计算能力&#xff0c;后者已经在各行各业“大杀四方”。当两者相遇会碰撞出什么样的火花&#xff1f;人工智能又能在哪些方面助力量子技术&#…

1 操作系统第一章 操作系统概念、功能、四大特征、操作系统发展与分类

文章目录1.1 操作系统概念1.2 操作系统功能1.3 操作系统四大特征1.3.1 并发1.3.2 共享1.3.3 并发性和共享区别及对应关系&#xff1a;1.3.4 虚拟1.3.5 异步1.4 操作系统的发展与分类1.4.1 手工操作阶段1.4.2 批处理阶段——单道批处理系统1.4.3 批处理阶段——多道批处理系统1.…

不能头脑一热,就布局颠覆性技术、上马未来产业

来源&#xff1a;财经国家周刊作者&#xff1a;曹方 何颖 姬少宇 张鹏近年来&#xff0c;布局、规划及培育人工智能与机器人、先进材料、新能源、生命科学、云计算和量子计算、混合现实等颠覆性技术、未来产业&#xff0c;成为不少地方政府推动当地产业结构调整、助力经济高质量…

2 操作系统第一章 操作系统体系结构、中断和异常、系统调用

文章目录1.1 指令概念及其分类1.2 操作系统体系结构&#xff1a;1.2.1操作系统内核概念1.3 中断和异常1.3.1 中断的诞生1.3.2 中断分类1.3.3 外中断的处理过程1.3.4 中断小结1.4 系统调用1.4.1 系统调用介绍1.4.2 系统调用功能1.4.3 系统调用小结1.1 指令概念及其分类 指令就是…