删除顺序表中所有值为X的元素(顺序表,单链表)

2024-04-19 17:04

本文主要是介绍删除顺序表中所有值为X的元素(顺序表,单链表),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

时间复杂度为O(1)(顺序表):代码实现:

运行结果:

时间复杂度为O(n)(顺序表):代码实现:

运行结果:

单链表:时间复杂度o(n):代码实现:


时间复杂度为O(1)(顺序表):代码实现:

#include<iostream>
using namespace std;
#define MAXSIZE 100
#define ok -1
#define error -2
typedef int Status;
typedef int ElemType; 
typedef struct
{ElemType *elem;int length;
}Sqlist;
Status InitList(Sqlist &L);
void chushi(Sqlist &L,int x);
void shuchu(Sqlist L); 
Status GetElem(Sqlist L,int i,ElemType &e);
Status ListInsert(Sqlist &L,int i,ElemType e);
Status Delete(Sqlist &L,int i);
Status Sort(Sqlist &L);
void SequenceSort(Sqlist &L,ElemType x);
void delete1(Sqlist &L,int x);
int main()
{Sqlist L;int x,i,j;Status m;ElemType e;x=InitList(L);if(x==error) cout<<"初始化失败"<<endl;else      	 cout<<"初始化成功"<<endl;cout<<"请决定输入元素的个数";cin>>x;chushi(L,x); cout<<"此时顺序表为:"<<endl;shuchu(L);cout<<endl<<"请输入要删除的元素";cin>>x;delete1(L,x);cout<<"删除后的表为"<<endl;shuchu(L);return 0;
}
Status InitList(Sqlist &L)//初始化开辟空间 
{L.elem=new ElemType[MAXSIZE];if(!L.elem) return error;L.length=0;return ok;
}
void chushi(Sqlist &L,int x)//初始化赋值 
{ElemType m;for(int i=0;i<x;i++){cout<<"请对第"<<i+1<<"个位置赋值";cin>>m;L.elem[i]=m;L.length++;}
}void shuchu(Sqlist L)//输出操作 
{cout<<"顺序表为:";for(int i=0;i<L.length;i++){cout<<L.elem[i]<<"  ";}
} 
void delete1(Sqlist &L,int x){int i=0,k=0;for(int i=0;i<L.length;i++){if(L.elem[i]!=x){L.elem[k]=L.elem[i];k++;}}L.length-=L.length-k;
}

运行结果:

时间复杂度为O(n)(顺序表):代码实现:

#include<stdio.h>
#include"sqlist.cpp"
/*已知长度为n的线性表A采用顺序存储结构,
编写一个时间复杂度为O(n)、空间复杂度为O(1)的算法,
该算法删除线性表中所有值为x的数据元素。
*/
void DeleteNode1(SqList *&L,ElemType x)
{int k=0;//k记录元素值不等于x的个数for(int i=0;i<L->length ;i++){if(L->data [i]!=x)//若当前元素不为x,则将其插入到L中 {L->data[k]=L->data[i];k++;}} L->length = k;
}
//算法1类似于建顺序表void DeleteNode2(SqList *&L,ElemType x)
{int k=0;for(int i=0;i<L->length ;i++){if(L->data [i]==x)//当前元素为x时k增1 {k++;}else{L->data [i-k]=L->data [i];//当前元素不为x时将其前移k个位置 }}L->length -= k;//顺序表L的长度减K 
}
int main(int argc,char *argv[])
{ElemType x;ElemType a[]={1,2,2,1,0,2,4,2,3,1};SqList *L;InitList(L);//初始化线性表CreateList(L,a,10);//数组名代表数组元素的首地址 printf("L:");DisplayList(L);printf("请输入要删除元素的值:");scanf("%d",&x);printf("删除值为%d的元素 \n",x);
//	DeleteNode1(L,x); DeleteNode2(L,x);printf("L:");DisplayList(L);DestroyList(L);return 0;
}
运行结果:

单链表:时间复杂度o(n):代码实现:
#include<iostream>
using namespace std;
#define ok -1
#define error -2
typedef int Status;
typedef int ElemType; 
typedef struct LNode
{ElemType data;struct LNode *next;
}LNode,*LinkList;
Status InitList(LinkList &L);
Status fuzhi(LinkList &L,int m);
void shuchu(LinkList L);
Status ListInsert(LinkList &L,int m,ElemType y);
Status Delete(LinkList &L,int n);//删除
void Sort(LinkList &L);
Status Length(LinkList L);
void SequenceSort(LinkList &L,ElemType x);
void delete1(LinkList &L,int x);
int main()
{LinkList L;int x,m,n;ElemType y;x=InitList(L);if(x==error) cout<<"初始化失败";else         cout<<"初始化成功"<<endl;cout<<"请决定输入几个元素";cin>>m;x=fuzhi(L,m);if(x==error) cout<<"赋值失败";shuchu(L);cout<<"请决定删除元素:";cin>>x;delete1(L,x);shuchu(L);return 0;
}
Status InitList(LinkList &L)
{L=new LNode;if(L==NULL) return error;L->next=NULL;return ok;
}
Status fuzhi(LinkList &L,int m)
{LNode *s,*r=L;ElemType n;for(int i=1;i<=m;i++){cout<<"请输入第"<<i<<"个元素";cin>>n; s=new LNode;s->data=n;r->next=s;r=s;}r->next=NULL;return ok;
}
void shuchu(LinkList L)
{LNode *p;p=L->next;cout<<"单链表内容为:";while(p!=NULL){cout<<p->data<<" ";p=p->next;}cout<<endl;
}
void delete1(LinkList &L,int x){LNode *p,*s;p=L;while(p){if(p->next->data==x){s=p->next;p->next=s->next;delete s;}p=p->next;}
}

这篇关于删除顺序表中所有值为X的元素(顺序表,单链表)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/918123

相关文章

Python pip下载包及所有依赖到指定文件夹的步骤说明

《Pythonpip下载包及所有依赖到指定文件夹的步骤说明》为了方便开发和部署,我们常常需要将Python项目所依赖的第三方包导出到本地文件夹中,:本文主要介绍Pythonpip下载包及所有依... 目录步骤说明命令格式示例参数说明离线安装方法注意事项总结要使用pip下载包及其所有依赖到指定文件夹,请按照以

Redis过期删除机制与内存淘汰策略的解析指南

《Redis过期删除机制与内存淘汰策略的解析指南》在使用Redis构建缓存系统时,很多开发者只设置了EXPIRE但却忽略了背后Redis的过期删除机制与内存淘汰策略,下面小编就来和大家详细介绍一下... 目录1、简述2、Redis http://www.chinasem.cn的过期删除策略(Key Expir

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co

使用C#删除Excel表格中的重复行数据的代码详解

《使用C#删除Excel表格中的重复行数据的代码详解》重复行是指在Excel表格中完全相同的多行数据,删除这些重复行至关重要,因为它们不仅会干扰数据分析,还可能导致错误的决策和结论,所以本文给大家介绍... 目录简介使用工具C# 删除Excel工作表中的重复行语法工作原理实现代码C# 删除指定Excel单元

Python对PDF书签进行添加,修改提取和删除操作

《Python对PDF书签进行添加,修改提取和删除操作》PDF书签是PDF文件中的导航工具,通常包含一个标题和一个跳转位置,本教程将详细介绍如何使用Python对PDF文件中的书签进行操作... 目录简介使用工具python 向 PDF 添加书签添加书签添加嵌套书签Python 修改 PDF 书签Pytho

MySQL中SQL的执行顺序详解

《MySQL中SQL的执行顺序详解》:本文主要介绍MySQL中SQL的执行顺序,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql中SQL的执行顺序SQL执行顺序MySQL的执行顺序SELECT语句定义SELECT语句执行顺序总结MySQL中SQL的执行顺序

C#实现查找并删除PDF中的空白页面

《C#实现查找并删除PDF中的空白页面》PDF文件中的空白页并不少见,因为它们有可能是作者有意留下的,也有可能是在处理文档时不小心添加的,下面我们来看看如何使用Spire.PDFfor.NET通过C#... 目录安装 Spire.PDF for .NETC# 查找并删除 PDF 文档中的空白页C# 添加与删

SQL常用操作精华之复制表、跨库查询、删除重复数据

《SQL常用操作精华之复制表、跨库查询、删除重复数据》:本文主要介绍SQL常用操作精华之复制表、跨库查询、删除重复数据,这些SQL操作涵盖了数据库开发中最常用的技术点,包括表操作、数据查询、数据管... 目录SQL常用操作精华总结表结构与数据操作高级查询技巧SQL常用操作精华总结表结构与数据操作复制表结

SpringBoot中配置文件的加载顺序解读

《SpringBoot中配置文件的加载顺序解读》:本文主要介绍SpringBoot中配置文件的加载顺序,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录SpringBoot配置文件的加载顺序1、命令⾏参数2、Java系统属性3、操作系统环境变量5、项目【外部】的ap

redis过期key的删除策略介绍

《redis过期key的删除策略介绍》:本文主要介绍redis过期key的删除策略,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录第一种策略:被动删除第二种策略:定期删除第三种策略:强制删除关于big key的清理UNLINK命令FLUSHALL/FLUSHDB命