顺序表删除值为 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 ...
随机推荐
- 数据结构之排序技术:快速排序、归并排序、堆排序(C++版)
快速排序 #include <iostream> using namespace std; void swap(int num[], int i, int j) { int temp = ...
- 高质量C++C编程指南笔记 标签: c++笔记 2015-11-22 20:59 179人阅读 评论(0) 收藏
1. 在多重循环中,如果有可能,应当将最长的循环放在最内层,最短的循环放在最外层,以减少 CPU 跨切循环层的次数. 2. 如果循环体内存在逻辑判断,并且循环次数很大,宜将逻辑判断移到循环体的外面 ...
- codeforces 848B Rooter's Song
题目链接 正解:排序+模拟. 我们注意到两个点碰撞的必要条件,$pi+tj=pj+ti$,移项以后发现就是$pi-ti=pj-tj$,那么我们可以把$p-t$相同的点分为同一组. 然后我们还可以发现一 ...
- UVA10820 Send a Table
嘟嘟嘟 [欧拉函数] 大致题意:如果知道f(a, b),就可以求出f(a * k, b * k).现给出一个n,求至少需要知道几个二元组(a, b),使所有的f(x, y)都能求出来.(1 <= ...
- select、poll和epoll比较
select select能监控的描述符个数由内核中的FD_SETSIZE限制,仅为1024,这也是select最大的缺点,因为现在的服务器并发量远远不止1024.即使能重新编译内核改变FD_SETS ...
- ROBOCOPY——Windows 的可靠文件复制
复制指定类型文件 (-s :含子目录 不包括空目录) 复制所有 (-e :含子目录 包括空目录) 复制指定成层级内的 (-lev:n 仅复制源目录树的前 n 层) 复制排除给定类型后的 (-xf) ...
- Android客户端与服务器端通过DES加密认证
转载地址:http://blog.csdn.net/spring21st/article/details/6730283 由于Android应用没有像web开发中的session机制,所以采用PHPS ...
- HDU 2092 (将表达式变成一元二次方程形式)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2092 整数解 Time Limit: 1000/1000 MS (Java/Others) Me ...
- react native基本调试技巧
刚入坑RN,很多小坑都要摸索很久才明白.今天咱们就来填console.log()的坑. 废话不多说,开始讲步骤!! 1.在模拟器中打开 开发者菜单,选择 Debug JS Remotely,会自动在浏 ...
- 【转载】python发送邮件实例
本文转自:http://www.cnblogs.com/lonelycatcher/archive/2012/02/09/2343463.html 这几天要用python发送邮件,上网找到这篇文章感觉 ...