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

单链表的插入和删除

文章目录

  • 单链表的插入和删除
    • 1 单链表插入
    • 2 单链表删除
    • 3 代码实现

1 单链表插入

要想将结点s插入到ai与ai+1之间,不需要移动数据元素,只需要在ai与ai+1之间插入一个新的结点,也就是我们要插入的结点s。关键就是要修改结点p的指针域,使得结点s称为其后继。
在这里插入图片描述

修改指针的链接的主要操作语句是:

1.  s->next=p->next;         //把结点p的后继作为结点s的后继;
2.  p->next=s;              //把结点s作为结点p的后继;

注意这两个语句的顺序不能调换不能调换不能调换!!!

为什么呢?如果调换①和②的顺序,那么插入操作就无法完成,并且会丢失ai结点的地址以及ai及其后面所有结点的信息。


2 单链表删除

删除操作和插入类似,在删除一个结点时,不需要移动元素,仅需要修改相应的指针链接,改变其前驱和后继的关系即可。
在这里插入图片描述

主要操作语句为(要借助辅助指针变量q):

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

3 代码实现

以下代码实现了 单链表的按位置插入和删除

#include <stdio.h>
#include <stdlib.h>
#include <time.h>typedef int ElementType;
typedef struct node {ElementType data;struct node *Next;
} *List;List CreateList(void)
{List L = (List)malloc(sizeof(struct node));L->data = 0;L->Next = NULL;return L;
}void InitList(List L)
{srand((unsigned)time(NULL));for (int i = 0; i < 10; i++) {List p = (List)malloc(sizeof(struct node));p->data = rand() % 100;p->Next = L->Next;L->Next = p;}
}List Find(List L, int position)
{List p = L;int i = 0;while (p->Next && i < position) {p = p->Next;i++;}if (i == position) {return p;} else {return NULL;}
}void Insert(List L, int position, ElementType e)
{List p;List tmp;if (p = Find(L, position - 1)) {tmp = (List)malloc(sizeof(struct node));tmp->data = e;tmp->Next = p->Next;;p->Next = tmp;}
}void Delete(List L, int position)
{List p;List tmp;if (p = Find(L, position - 1)) {tmp = p->Next;p->Next = tmp->Next;free(tmp);}
}void PrtList(List L)
{List p = L->Next;while (p) {printf("%d ", p->data);p = p->Next;}printf("\n");
}int main(void)
{ElementType e;int position;List L = CreateList();InitList(L);PrtList(L);printf("please input position and element to insert:");scanf("%d%d", &position, &e);Insert(L, position, e);PrtList(L);printf("please input position to delete:");scanf("%d", &position);Delete(L, position);PrtList(L);return 0;
}

运行结果如下图:
在这里插入图片描述

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

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

相关文章

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 指令概念及其分类 指令就是…

百年诺奖的那些争议与放弃

来源&#xff1a;数学与通识自1901年首届诺贝尔奖颁发以来&#xff0c;它已成为人们心中最崇高、最向往的奖项之一。可能没有人想要去拒绝它&#xff0c;因为它不仅仅是奖金的问题&#xff0c;还是莫大的荣誉和骄傲&#xff0c;其追求真理、造福社会、为人类文明创造价值的初心…

3 操作系统第二章 进程管理 进程定义、特征、组织、状态与转换

文章目录1 进程的定义和特征2 进程的组织3 进程的状态与转换3.1 进程的状态3.2 进程状态转换1 进程的定义和特征 引入进程的原因 为了使程序能够并发执行&#xff0c;并且可以对并发执行的程序加以描述和控制 进程定义 进程是进程实体的运行过程&#xff0c;是系统进行资源分配…

数学家、中科院院士张景中:数学实力影响国家实力是近代以来的共识

本文转自&#xff1a;长江日报-长江网转载自公众号 和乐数学长江日报-长江网讯(记者周劼)最近一段时间&#xff0c;关于“数学”的热点新闻接连不断&#xff0c;从华为爆料有700名数学家&#xff0c;到中国重夺国际奥数冠军&#xff0c;从丘成桐区别数学家和数学工程师&#xf…

4 操作系统第二章 进程管理 进程控制、通信

文章目录1 进程控制1.1 进程控制1.2 进程控制实现1.3 进程创建1.4 进程终止1.5 进程阻塞与唤醒1.6 进程切换1.7 进程控制小结2 进程通信2.1 共享通信2.2 管道通信2.3 消息传递2.4 进程通信小结1 进程控制 1.1 进程控制 进程控制的主要功能是对系统中的所有进程实施有效的管理&…