单链表删除所有值为x的元素_线性表之单链表

 单链表

一种以链接方式存储的线性表,适用于频繁增删操作,存储空间不定的情形。

单链表的一个存储结点包含两个域,数据域和指针域。数据域用于存储线性表的一个数据元素,指针域用于指示下一个结点开始的存储地址。

b51a6a8a592f7d0b3237826f81342528.png

链表第一个结点的地址可通过头指针找到,其他结点的地址则在前驱结点的指针域中,最后一个结点没有后继,用NULL终结。

cc697b8cc175d4d2473d1725b16783fe.png

为了操作的方便,习惯上单链表带一个头结点,也就是first指向的第一个结点不存放任何数据,从第二个结点开始存放数据。

881f993194f6a4599bc66db8bf99665f.png

由于指针域的存在,数据元素的顺序与物理存储顺序可能不一致。

e8eadd10c8133f775ad26c1e3489d2da.png

定义与封装

//结点的定义
struct LinkNode {        //链表结点类的定义int data;           //数据域
    LinkNode *link;     //链指针域

    LinkNode() { link = NULL; }     //构造函数
    LinkNode(int item, LinkNode *ptr = NULL)
    { data = item;  link = ptr; }     //构造函数
};
//链表操作封装
class List{protected:LinkNode *first;     //表头指针,头结点public:
    List() { first = new LinkNode; }  //构造函数
    List(int x) { first = new LinkNode(x); }
    ~List(){ }                  //析构函数void inputFront (int val);LinkNode *Search(int x);    //搜索含x元素LinkNode *Locate(int i);    //返回第i个元素地址bool Insert (int i, int x); //在第i元素后插入bool Remove(int i, int& x); //删除第i个元素bool IsEmpty() const         //判表空否{ return first->link == NULL ? true : false; }void show();
};

带附加头结点的插入操作

1、newnode->link = p->link; 

2、p->link = newnode;

c81239242ffbbb40fd5570b547ba6011.png

注意图中标1和2的位置与代码相结合

//将新元素 x 插入在链表中第 i 个结点之后。
bool List::Insert (int i, int x) {
    LinkNode *current = Locate(i);if (current == NULL) return false;   //无插入位置 LinkNode *newNode = new LinkNode(x); //创建新结点    //图中标识的1处,在不破坏原链表的情况下让新结点先链入
    newNode->link = current->link;       //链入    //图中标识的2处,接到新结点
    current->link = newNode;  
          return true;                
}

带附加头结点的查找操作

查找过程就是从第一个结点开始不断沿着link域寻到和所需值相同的结点

//在表中搜索含数据x的结点, 搜索成功时函数返//该结点地址; 否则返回NULL。
LinkNode *List::Search(int x) {
     LinkNode *current = first->link;while( current != NULL && current->data != x )      
        current = current->link;    //沿着链找含有x的结点
return current;
}

带附加头结点的删除操作

1、q = p->link;

2、p->link = q->link;

3、delete q; 

7ea861224de9bb6c887fb1ec680e1eae.png

//删除链表第i个元素, 通过引用参数x返回元素值
bool List::Remove (int i, int& x ) {//图中指针p
    LinkNode *c
urrent = Locate(i-1);if(current == NULL || current->link == NULL)   return false;     //删除不成功      //图中指针q
    LinkNode *del = current->link; 
    //图中操作2,p的link指向指针q的link指向的域,越过q
    current->link = del->link;

    x = del->data;    //脱节的q可以直接删除   delete del; return true;
}

附加头结点的单链表创建

一般单链表的创建可采用前插法或者尾插法,

前插法就是每来一个新的结点,就把这个结点插在头结点的后面。

尾插法就是每来一个新的结点就把这个结点插在链表最后一个结点的后面,相比前插法需要设置一个尾指针。

实现插入过程和链表的插入操作几乎无区别。

void List::inputFront (int val) {
    LinkNode *newNode = new LinkNode;if(newNode==NULL) return;
    newNode = new LinkNode(val);newNode->link = first->link;      //插在表前端
    first->link = newNode;

}

优点:

长度很容易方便扩充。

缺点:

存储空间上多了指针域,存储空间代价比顺序表大。

至于带附加头节点和不带附加头节点的好处,看过书的同学都知道,前者的增删操作更简练

代码https://github.com/xiaoYaChh/datastructure.git

参考资料:数据结构第二版,殷人昆,清华大学出版社

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

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

相关文章

PHP自动测试框架Top 10

2019独角兽企业重金招聘Python工程师标准>>> 对于很多PHP开发新手来说,测试自己编写的代码是一个非常棘手的问题。如果出现问题,他们将不知道下一步该怎么做。花费很长的时间调试PHP代码是一个非常不明智的选择,最好的方法就是在编…

树莓派 设备信息 php,树莓派实现DDNS(PHP计划任务)

之前介绍了DNSPod动态IP解析更新程序,是Python实现的。下面介绍一个PHP实现的脚本,实现了同样的动态域名解析功能。header("Content-type: text/html; charsetutf8");class Dns{#Dnspod账户private $dnspod_user userexample.com;#Dnspod密码…

某公司数据恢复报告书

一、故障描述1、设备清单设备名称设备型号数量HP FC存储HP MSA20001450G SAS.硬盘82、故障描述整个存储空间由8块450GB SAS的硬盘组成,其中7块硬盘组成一个RAID5的阵列,剩余1块做成热备盘使用。由于RAID5阵列中出现2块硬盘损坏,而此时只有一块…

java里的时间转换

2019独角兽企业重金招聘Python工程师标准>>> http://cwind.iteye.com/blog/1908589 http://dyccsxg.iteye.com/blog/1908607 转载于:https://my.oschina.net/mustang/blog/608365

command对象提供的3个execute方法是_并发面试题:java中有几种方法可以实现一个线程?...

创建并启动线程的6种方式 继承Thread类创建线程实现Runnable接口创建线程使用Callable和FutureTask创建线程使用线程池,例如用Executor框架Spring实现多线程(底层是线程池)定时器Timer (底层封装了一个TimerThread对象&#xff09…

matlab中如何提取等高线,在Python或MATLAB中从等高线图中提取数据

这是一个小型的Matlab脚本,可以完成这项工作(使用一些GUI,在图的斜角处读取guidlines):%// Import the data:imdata importdata(your_picture_file);Gray rgb2gray(imdata.cdata);colorLim [-1 1]; %// this should be set manually%// Ge…

【Android Studio】分类整理res/Layouts中的布局文件(创建子目录)

好吧,这个功能需求也是因为作为一个重度强迫症患者,非常想要把layouts中的文件分类整理下。否则看到一堆Activity和Fragment等文件混在一起特别难受。更重要的原因是,如果你的工程交给别人维护,别人看到一堆布局文件压根不知道从哪…

SQL排序查询

1.建一张客户表,包含客户名称,联系人,电话号码,公司地址. 2.建一张订单表,包含订单编号,客户ID,供应商ID,订单金额,客户支付状态,供应商支付状态,订单日期. 3.建一张供应商表&#x…

mysql8创建用户并授权_新特性解读 | 从 wireshark 看 MySQL 8.0 加密连接

作者:秦福朗爱可生 DBA 团队成员,负责项目日常问题处理及公司平台问题排查。热爱 IT,喜欢在互联网里畅游,擅长摄影、厨艺,不会厨艺的 DBA 不是好司机,didi~本文来源:原创投稿*爱可生开源社区出品…

DP备份任务失败原因解析

以JDC为例,DP的备份任务失败troubleshooting流程为:1)/etc/opt/omni/server/datalist下都是备份的job code。如果要查看一个job code,可以more 此文件夹下的某个datalist,输入如下:最上面的两个脚本pre和post&#xff…

mysql求表中年龄同张三,mysql子查询与连接查询

表结构以及数据:CREATE TABLEstudent (idint(11) NOT NULLAUTO_INCREMENT,namevarchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL,ageint(11) NULL DEFAULT NULL,PRIMARY KEY(id) USING BTREE) ENGINE InnoDB AUTO_INCREMENT 13 CHARACT…

jenkins war包_Jenkins的安装和部署(jenkins教程)

一、jenkins的下载、安装以及环境的搭建部署。1.什么是jenkins以及它的作用:Jenkins 是一个可扩展的持续集成(CI)平台。它只是一个平台,真正运作的都是插件。Jenkins的主要作用:持续的监控软件版本发布/测试项目。监控…

内存恶鬼drawRect

转载于:http://bihongbo.com/内存恶鬼drawRect 标题有点吓人,但是对于drawRect的评价倒是一点都不过分。在平日的开发中,随意覆盖drawRect方法,稍有不慎就会让你的程序内存暴增。下面我们来看一个例子。 去年的某天午后,北京的雾霾…

c#和python同一主机直接udp_为什么Python 如此之慢

原文:https://hackernoon.com/why-is-python-so-slow-e5074b6fe55b​hackernoon.comPython 正在爆炸般流行起来,它被用于DevOps, 数据处理,web开发和安全领域。但是在速度方面却没有取得过什么胜利。 Java在速度方面和C/C/C#/Python比起来如何&#xff…

lldb 调试php,linux系统下如何在vscode中调试C++代码

本篇博客以一个简单的hello world程序,介绍在vscode中调试C代码的配置过程。1. 安装编译器vscode是一个轻量的代码编辑器,并不具备代码编译功能,代码编译需要交给编译器完成。linux下最常用的编译器是gcc,通过如下命令安装&#x…

php负责传递数据,php传递数据的方法有哪些

php传递数据的方法有哪些发布时间:2021-03-19 09:10:54来源:亿速云阅读:58作者:小新这篇文章将为大家详细讲解有关php传递数据的方法有哪些,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅…

除了工作怎么交朋友_夫妻感情不好怎么办?夫妻关系紧张该如何解决?

夫妻感情不好怎么办?夫妻关系紧张该如何解决?1. 象征两人的兴趣随着年龄的增长而多样化。年轻的时候往往因为他们之间的差异而互相吸引,但当他们在中老年则需要更多的安慰或关心,理解,需求就不同了。当你发现自己的志向迥然不同时…

java websocket修改为同步_服务端向客户端推送消息技术之websocket的介绍

websocket的介绍在讲解WebSocket前,我们先来看看下面这种场景,在HTTP协议下,怎么实现。需求:在网站中,要实现简单的聊天,这种情况怎么实现呢?如下图:​当发送私信的时候,…

python random randint_python中random.randint和random.randrange的区别详解

在python中,通过导入random库,就能使用randint 和 randrange 这两个方法来产生随机整数。那这两个方法的区别在于什么地方呢?让我们一起来看看! 区别: randint 产生的随机数区间是包含左右极限的,也就是说左右都是闭区…

How to change max_allowed_packet size

2019独角兽企业重金招聘Python工程师标准>>> How to change max_allowed_packet size up vote 116 down vote favorite 40I am having a problem with BLOB fields in my MySQL database - when uploading files larger than approx 1M…