如何删除顺序表中的重复单词:

(开始看内容之前容朕说一句:如果你最后怎么都运行不了你想要的结果,①我敢保证大概率是你的下标越界你的下标越界了你的下标越界了。②在我这程序里面你肯定打少了p--,少了p--,少了p--,少了p--

在一个顺序表中,所有元素都是有序着排放着,所以在遍历重复的时候就需要灵活利用下标位置。

我们拿第一个单词元素为例子,用一个临时数组存放单词,方便后面用下标和strcmp函数进行比较单词是否重复。

从第一个单词元素往后遍历,下标为0,我们用一个变量c存放该下标,在往后遍历是否有重复的时候我们不能用这个变量,(这里看不懂的先不解释,我后面会说)。这时候我们继续定义一个变量p存放c+1c位置的后继,也就是c下标的下一个单词元素下标,这时候我们就进入遍历重复的操作,p不断通过自增的操作往后搜寻重复的单词元素

当遇到一个重复的单词元素,再定义一个变量gt存放当前p的下标,在该位置用gt来对顺序表进行删除操作,该位置往后的元素都把前趋覆盖掉,也就当前位置的后面每一个元素都往前移动一步,就实现了对该位置上元素的覆盖,也就是对该单词实行了删除操作。

如果p还没有到末尾,也就是第一个单词还没有把所有的元素比较完,p后面可能还要重复的单词,所以这时候回到p当前的位置,继续向前比较,若遇到相同单词继续重复上述删除操作,直到p到了顺序表的最末端就退出。

退出之后就表示第一个单词已经完全把和它重复的单词删除完毕,这时候就要用到c了,c还存放着是第一个单词元素下标0,我们对他进行自增操作,来到了第二个单词元素,这样我们又对他进行上述一系列操作,直到倒数第二个为止

为什么是倒数第二个??

原因1:你其实到了倒数第二个的时候p背赋值为c+1,也就是已经把末端和倒数第二个进行了比较了,最后一个得后面也没有后继,无法再继续比较了。

原因2:如果细心点就会发现我们的p是被赋值为c+1,如果我们直到c等于末端才结束,那造成了越界,调试的时候在该地方会提示你在该代码段会有内存泄漏,程序运行不出结果,但是编译不会出错,只有你调试的时候会提示你。

程序需要很严密的逻辑,不能对下标有任何模糊的使用,稍不注意就会造成下标的越界,代码段出错,还有一个需要重点关注的地方是当你把元素往前覆盖完成后,要回到该位置,所以我在完成覆盖操作之前把p--了,因为我一出去就要p++,如果不减一,出去之后就不是该位置,而是当前位置的后继。

为什么一定要回到这个位置呢??

因为你遇到相同单词的这个位置是被删除掉的,当前位置存放的已经不是你之前那个单词,是用后继覆盖掉的单词,万一这个单词还是重复的单词呢,你就删除不了了,因为你出去就p++,已经到了该位置的后继。

下面放函数代码

需要各位根据自己的程序进行改动,我仅提供方法,我用的变量名都是英语,可以翻译出来,大概能懂意思,上述中提到的变量p、c、gt我也用上了,方便各位阅读。

这是我宏定义的结构体和变量,以免看不懂我后面的代码意思。

!!但是这不能直接用的,因为在这之前我是已经把顺序表存好了单词和计算好了长度!!

/*顺序表*/

int F_link_len, F_maxword_len; //存放数组的顺序表的空间大小和最长单词的长度 

typedef struct _Elem{
char *word;//存放单词
int lenth;//后面用F_link_len计算好长度后直接赋值给lenth作为顺序表长度
}Elem; typedef struct _Elemlink{
Elem *array;//动态定义数组
int link_len;//数组长度
}Elemlink; Elemlink *Sqlink_Firefox = NULL;

这是删除顺序表中重复单词元素具体实现操作:

char cmp[F_maxword_len+1];//加一避免空间越界
int c = 0, p, start = -1, gt;//c一定要先赋值为0下标 while(1)
{
strcpy(cmp, Sqlink_Firefox->array[c].word);
//先对两个辅助变量赋值好
p = c+1;
while(1)
{ //如果是遇到最后一个才发现是相同的单词那就直接把数组长度减一
if(strcmp(cmp, Sqlink_Firefox->array[p+1].word) == 0 && p+1 == F_link_len - 1) F_link_len--; //表示找到相同的 ,先从该位置进行向前移动,之后回到p+1 的位置进行再次寻找是否有相同的
if(strcmp(cmp, Sqlink_Firefox->array[p].word) == 0 && p < F_link_len - 1)
{
gt = p;//记录从这个地方开始有重复,但是还要继续判断该位置后面的元素是否还有重复,所以先把下标记录下来
while(1)
{
strcpy(Sqlink_Firefox->array[gt].word, Sqlink_Firefox->array[gt+1].word);
if(gt < F_link_len-1) gt++;//继续移动位置
if(gt == F_link_len-1) break;//若到了最后一个位置就退出该循环
}
F_link_len--;//数组元素个数减一
p--;//因为下面我是p++,为了让p回到原本那个位置,我先减一再加一,就是原来遇到相同单词的那个位置
}
p++;
if(p >= F_link_len - 1) break;//表示已经全部遍历完成 ,同时判断进来的p是否已经到末尾了
} c++;
if(c == F_link_len-1) break; }

C语言:删除顺序表中重复的信息—(删除顺序表中重复的单词)的更多相关文章

  1. oracle中查询表的信息,包括表名,字段名,字段类型,主键,外键唯一性约束信息

    来源于网上整理 总结了一下oracle中查询表的信息,包括表名,字段名,字段类型,主键,外键唯一性约束信息,索引信息查询SQL如下,希望对大家有所帮助: 1.查询出所有的用户表select * fro ...

  2. PostgreSQL:查询元数据(表 、字段)信息、库表导入导出命令

    一.查询表.模式及字段信息 1.查询指定模式下的所有表 select tablename,* from pg_tables where schemaname = 'ods'; 2.查询指定模式下的表名 ...

  3. ArcGIS中删除“点”附带的对应“文本信息”

    现状: 用ArcMap打开对应的.mxd文件,导入KML数据后,几何类型“点” - 每一个点都附带对应的文本信息“Placemark”,如下图: 问题:ArcGIS中如何 删除“点”附带的对应“文本信 ...

  4. 如何删除GIT仓库中的敏感信息

    如何删除GIT仓库中的敏感信息 正常Git仓库中应该尽量不包含数据库连接/AWS帐号/巨大二进制文件,否则一旦泄漏到Github,这些非常敏感信息会影响客户的信息安全已经公司的信誉.公司可能其它还有相 ...

  5. Python之向日志输出中添加上下文信息

    除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定信息,如:远程客户端的IP地址和用户名.这里我们 ...

  6. 【转】Python之向日志输出中添加上下文信息

    [转]Python之向日志输出中添加上下文信息 除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定 ...

  7. Python 日志输出中添加上下文信息

    Python日志输出中添加上下文信息 除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定信息,如: ...

  8. [Android Pro] 查看 keystore文件的签名信息 和 检查apk文件中的签名信息

    1: 查看 keystore文件的签名信息 keytool -list -v -keystore keystoreName -storepass keystorePassword 2: 检查apk文件 ...

  9. 在Scrapy中如何利用Xpath选择器从HTML中提取目标信息(两种方式)

    前一阵子我们介绍了如何启动Scrapy项目以及关于Scrapy爬虫的一些小技巧介绍,没来得及上车的小伙伴可以戳这些文章: 手把手教你如何新建scrapy爬虫框架的第一个项目(上) 手把手教你如何新建s ...

  10. oracle中的rowid--伪列-删除表中的重复内容-实用

    1.rowid是一个伪列,是用来确保表中行的唯一性,它并不能指示出行的物理位置,但可以用来定位行. 2.rowid是存储在索引中的一组既定的值(当行确定后).我们可以像表中普通的列一样将它选出来. 3 ...

随机推荐

  1. #交互,分类讨论#CF1292E Rin and The Unknown Flower

    题目传送门 分析 先尝试锁定一个字母,显然询问 \(CH,CO,CC\) 会比直接询问 \(C\) 更优,虽然牺牲了最后一个位置是否为 \(C\) 的查询. 同理,询问 \(HH,OH,CH\) 会比 ...

  2. #后缀数组#洛谷 4051 [JSOI2007]字符加密

    题目 分析 将字符串复制一份放入末尾,将其后缀排序之后 SA数组既然表示排名为\(i\)的后缀的起始位置, 那么只要它在\([1,len]\)范围内就是合法的, 那么输出以这个位置开头长度为\(len ...

  3. 使用OHOS SDK构建vorbis

    参照OHOS IDE和SDK的安装方法配置好开发环境. 从github下载源码. 执行如下命令: git clone --depth=1 https://github.com/xiph/vorbis ...

  4. 【开源三方库】crypto-js加密算法库的使用方法

     OpenAtom OpenHarmony(简称"OpenHarmony")三方库,是经过验证可在OpenHarmony系统上可重复使用的软件组件,可帮助开发者快速开发OpenHa ...

  5. Aspose.Cells使用总结大全

    引用:https://blog.csdn.net/u011555996/article/details/79000270 使用到 Aspose.Cells 插件,整理一下. 一:新建解决方案,目录如下 ...

  6. HarmonyOS卡片刷新服务,信息实时更新一目了然

    如今衣食住行娱乐影音等App占据了大多数人的手机,一部手机可以满足日常大多需求,但对需要经常查看或进行简单操作的场景来说,总需要用户点开App操作未免过于繁琐. 针对该问题, HarmonyOS SD ...

  7. Drop 、Delete、Truncate的区别是什么

    Drop .Delete.Truncate 的区别是什么? DROP 删除表结构和数据,truncate 和 delete 只删除数据 truncate 操作,表和索引所占用的空间会恢复到初始大小:d ...

  8. css block,inline和inline-block概念和区别

    总体概念 block和inline这两个概念是简略的说法,完整确切的说应该是 block-level elements (块级元素) 和 inline elements (内联元素).block元素通 ...

  9. 重新整理数据结构与算法(c#)——算法套路普利姆算法[二十九]

    前言 看一个题目: 这个问题就是求最小生成树,是图转换为树的一种方式. 最小生成树概念: 最小生成树简称MST. 1.n个顶点,一定有n-1条边 2.包含全部顶点. 3.图转换为最小生成树,权重之和最 ...

  10. 使用pycuda替换字符串,使用cuda替换字符串

    写一个python的cuda程序,实现字符串列表的字符串替换,把所有的123替换成xinyuuliu 以下是一个简单的 Python CUDA 代码示例,用于实现字符串列表的字符串替换.它使用了 NV ...