删除顺序表中所有值为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

相关文章

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

macOS无效Launchpad图标轻松删除的4 种实用方法

《macOS无效Launchpad图标轻松删除的4种实用方法》mac中不在appstore上下载的应用经常在删除后它的图标还残留在launchpad中,并且长按图标也不会出现删除符号,下面解决这个问... 在 MACOS 上,Launchpad(也就是「启动台」)是一个便捷的 App 启动工具。但有时候,应

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

利用Go语言开发文件操作工具轻松处理所有文件

《利用Go语言开发文件操作工具轻松处理所有文件》在后端开发中,文件操作是一个非常常见但又容易出错的场景,本文小编要向大家介绍一个强大的Go语言文件操作工具库,它能帮你轻松处理各种文件操作场景... 目录为什么需要这个工具?核心功能详解1. 文件/目录存javascript在性检查2. 批量创建目录3. 文件

C++从序列容器中删除元素的四种方法

《C++从序列容器中删除元素的四种方法》删除元素的方法在序列容器和关联容器之间是非常不同的,在序列容器中,vector和string是最常用的,但这里也会介绍deque和list以供全面了解,尽管在一... 目录一、简介二、移除给定位置的元素三、移除与某个值相等的元素3.1、序列容器vector、deque

C++常见容器获取头元素的方法大全

《C++常见容器获取头元素的方法大全》在C++编程中,容器是存储和管理数据集合的重要工具,不同的容器提供了不同的接口来访问和操作其中的元素,获取容器的头元素(即第一个元素)是常见的操作之一,本文将详细... 目录一、std::vector二、std::list三、std::deque四、std::forwa

C++原地删除有序数组重复项的N种方法

《C++原地删除有序数组重复项的N种方法》给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度,不要使用额外的数组空间,你必须在原地修改输入数组并在使用O(... 目录一、问题二、问题分析三、算法实现四、问题变体:最多保留两次五、分析和代码实现5.1、问题分析5.

SQL Server清除日志文件ERRORLOG和删除tempdb.mdf

《SQLServer清除日志文件ERRORLOG和删除tempdb.mdf》数据库再使用一段时间后,日志文件会增大,特别是在磁盘容量不足的情况下,更是需要缩减,以下为缩减方法:如果可以停止SQLSe... 目录缩减 ERRORLOG 文件(停止服务后)停止 SQL Server 服务:找到错误日志文件:删除