顺序表删除值为 x 的元素
思路:
不要去考虑删除的字眼,要考虑如何进行保存非 x 的值
这里提供两种解法,殊途同归:
1.将其中非 x 的元素统计并保存
2.统计为 x 的元素个数,并将非 x 的元素保存
注意事项:
注意这里代码由于使用了引用(&),只能在 C++ 中编译通过
使用指针的时候一定要注意开辟空间,否则之后可能发现无法预知的错误
代码如下:
#include <stdio.h>
#include <stdlib.h>
#define MaxSize 50
typedef int ElemType; typedef struct {
ElemType data[MaxSize];
int length;
} Sqlist; //将其中非 x 的元素统计并保存
void delnode1(Sqlist* &L, ElemType x) {
int k = , i;
for(i = ; i < L -> length; i++) {
if(L -> data[i] != x) {
L -> data[k] = L -> data[i];
k++;
}
}
L -> length = k;
} //统计为 x 的元素个数,并将非 x 的元素保存
void delnode2(Sqlist* &L, ElemType x) {
int k = , i;
for (i = ; i < L -> length; i++) {
if (L -> data[i] == x) {
k++;
} else {
L -> data[i - k] = L -> data[i];
}
}
L -> length -= k;
} void createList(Sqlist* &L, ElemType a[], int n) {
int i;
L = (Sqlist *)malloc(sizeof(Sqlist));
for (i = ; i < n; i++) {
L -> data[i] = a[i];
}
L -> length = n;
} void dispList(Sqlist *L) {
int i;
for (i = ; i < L -> length; i++) {
printf("%d ", L -> data[i]);
}
printf("\n");
} int main(int argc, char const *argv[]) {
Sqlist *L;
ElemType a[] = {, , , , , , , , , };
createList(L, a, );
printf("原始线性表:\n");
dispList(L);
delnode1(L, );
printf("删除 3 后:\n");
dispList(L);
delnode2(L, );
printf("删除 4 后:\n");
dispList(L);
return ;
}
轻点加号,代码即现
运行结果在这儿*^_^*
原始线性表: 删除 后: 删除 后:
9
顺序表删除值为 x 的元素的更多相关文章
- 数据结构顺序表删除所有特定元素x
顺序表类定义: template<class T> class SeqList : { public: SeqList(int mSize); ~SeqList() { delete[] ...
- 顺序表添加与删除元素以及 php实现顺序表实例
对顺序表的操作,添加与删除元素. 增加元素 如下图所示 对顺序列表 Li [1328,693,2529,254] 添加一个元素 111 ,有三种方式: a)尾部端插入元素,时间复杂度O(1); ...
- 线性表之顺序表C++实现
线性表之顺序表 一.头文件:SeqList.h //顺序线性表的头文件 #include<iostream> ; //定义顺序表SeqList的模板类 template<class ...
- SDUT OJ 顺序表应用2:多余元素删除之建表算法
顺序表应用2:多余元素删除之建表算法 Time Limit: 3 ms Memory Limit: 600 KiB Submit Statistic Discuss Problem Descripti ...
- SDUT OJ 顺序表应用1:多余元素删除之移位算法
顺序表应用1:多余元素删除之移位算法 Time Limit: 1000 ms Memory Limit: 650 KiB Submit Statistic Discuss Problem Descri ...
- 顺序表应用1:多余元素删除之移位算法(SDUT 3324)
Problem Description 一个长度不超过10000数据的顺序表,可能存在着一些值相同的"多余"数据元素(类型为整型),编写一个程序将"多余"的数据 ...
- 顺序表应用2:多余元素删除之建表算法(SDUT 3325)
题解: 每次询问一遍,如果已经存在就不用插入表中了. #include <stdio.h> #include <stdlib.h> #include <string.h& ...
- 顺序表C语言版
#include <stdio.h> /* * 顺序表最多输入N个数 */ #define N 10 #define OK 1 #define ERROR -1 struct sequeu ...
- hrbustoj 1545:基础数据结构——顺序表(2)(数据结构,顺序表的实现及基本操作,入门题)
基础数据结构——顺序表(2) Time Limit: 1000 MS Memory Limit: 10240 K Total Submit: 355(143 users) Total Accep ...
随机推荐
- linux系统开机突然黑屏,只有光标
以前系统都是好好的,今天开机黑屏了,只有一个光标可以看见其他东西都看不见了. 经过检查发现是磁盘满了,将不用的文件删除之后可以正常开机了.特此记录一下!!! 有人问黑屏了怎么删文件? 我采用的方法是W ...
- Spring学习总结之---装配Bean
Spring配置的可选方案 前言:Spring容器负责创建应用程序中的bean并通过DI来协调这些对象之间的关系,作为开发人员,你需要告诉Spring容器要创建那些Bean,以哪种方式创建,并且如何将 ...
- memcached php-memcache 扩展
1.安装 libevent wget https://github.com/downloads/libevent/libevent/libevent-2.0.21-stable.tar.gz tar ...
- shell-day1
shell概述:这里说的是命令行shell,例如"bash/sh/ksh/csh"(Unix/Linux系统).cmd.exe命令提示字符(windwos系统),这里主要介绍Uni ...
- 表空间常用sql汇总
表空间碎片相关:select tablespace_name, round(sqrt(max(blocks) / sum(blocks)) * (100 / sqr ...
- 理解Underscore中的flatten函数
最近是在所在实习公司的第一个sprint,有个朋友又请假了,所以任务比较重,一直这么久都没怎么更新了,这个周末赖了个床,纠结了一会儿决定还是继续写这个系列,虽然比较乏味,但是学到的东西还是很多的. 之 ...
- Struts2注解开发
Hibernate和spring框架的开发前边总结了,这次看一下流行的MVC流程框架Struts2的注解开发吧.Struts2主要解决了从JSP到Action上的流程管理,如何进行Uri和action ...
- [19/04/12-星期五] 多线程_任务定时调度(Timer、Timetask和QUARTZ)
一.Timer和Timetask 通过Timer和Timetask,我们可以实现定时启动某个线程. java.util.Timer 在这种实现方式中,Timer类作用是类似闹钟的功能,也就是定时或者每 ...
- 利用python进行数据分析——(一)库的学习
总结一下自己对python常用包:Numpy,Pandas,Matplotlib,Scipy,Scikit-learn 一. Numpy: 标准安装的Python中用列表(list)保存一组值,可以用 ...
- android application project 开发准备工作
1.下载对应的JDK.SDK http://www.androiddevtools.cn/ 2.创建安卓app应用模拟器Run时会出现如图情况 解决办法是: 启动 Android SDK Manage ...