首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >算法-删除字符串中的公共字符

算法-删除字符串中的公共字符

作者头像
chaibubble
发布于 2018-01-02 03:25:58
发布于 2018-01-02 03:25:58
4.3K00
代码可运行
举报
运行总次数:0
代码可运行

题目: 输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如,输入“They are students.”和”aeiou”,则删除之后的第一个字符串变成”Thy r stdnts.”

解题思路: 好未来那这道题做过笔试题目,首先最简单的思路就是两层循环遍历,下面将“They are students.”称为字符串1,将“aeiou”称为字符串2。每遍历到字符串2中的一个字符,就在字符串1中找到相同的字符,找到之后删除它,并将字符串1后面的字符整体向前移动1位。所以这个过程的时间复杂度是O(n^3),下面我们就可以考虑如何优化它了:

1.如何解决顺序存储结构中删除后整体移动的问题? 假设当前遍历到字符串2中的“a”,现在遍历字符串1,要求是是“a”的话就删除,那么这个要求换一个思路就是不是“a”就保留,在不申请新的空间的情况下,我们只需要把要保留的字符覆盖字符串中1原来的字符,要删除的字符不做覆盖,此时就需要有两个指针,一个在控制整体的遍历过程,一个记录要插入的位置:

可以看到,在遍历的过程中,如果没有出现要删除的字符的话,p1和p2一直在同步走(同步走的过程也是要覆盖的过程,一直在用p1的指向字符覆盖p2,只是他们指向相同,覆盖也就没有意义了),而出现了要删除的字符,p2会停下来,指示p1指向的字符要覆盖的位置,这样的话,我们就能避免每一次删除后的整体平移,这样的话时间复杂度还有O(n^2)。

2.如何避免两层遍历的嵌套? O(n^2)的时间复杂度是由遍历两个字符串产生的,能否应用一些方法避免循环嵌套的问题,引入hash表。 两个遍历嵌套的过程无非是为了找到字符串2中的字符在字符串1中是否出现,那么如果我们对字符串1建立hash表,在遍历字符串2时就可以根据hash索引直接找到要删除的字符,这样的话时间复杂度就可以降到O(n),下面考虑字符串2中出现重复字符的情况,无所谓啊,反正都是要删了的。 所以我们就能对字符串2建立一个hash表了,hash函数选择:(int)arr2[n]。在字符串2中出现的字符,在hash表中的值为1,未出现的字符表值为0。 hash表范围的选取: a :97 A :65 z :122 Z :90 标点符号还在字母之前,所以hash范围选成256就足够了。 所以总的来说,我们用一个O(256)的空间复杂度,将时间复杂度从O(n^2)将为O(n),所以如果n很大的话,这个替换是值得的。

代码实现:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#include "iostream"    

using namespace std;
void  DeleteChar(char arr1[],char arr2[]);
int main()
{   
  char str1[] = "They are students.";
  char str2[] = "aeiou";
  cout<<str1<<endl;
  DeleteChar(str1,str2);
  cout<<str1<<endl;
  getchar();
  return 0;
}
void  DeleteChar(char *arr1,char *arr2)
{
    if(arr1 == NULL && arr2 == NULL)
        return;
    //创建hash表
    int hash_table[256] = { 0 };
    char *p1 = arr1;
    char *p2 = arr2;
    int index =0;
    //遍历删除串
    while(*p2 != '\0')
    {
        hash_table[(int)*p2] = 1;
        p2++;
    }
    //遍历待删除串
    while (*p1 != '\0')
    {
        //该字符不需要删除
        if( 0 == hash_table[(int)*p1] )
        {
            arr1[index]= *p1;
            index++;
        }
        p1++;
    }
    arr1[index]='\0';
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-08-15 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【牛客网】OR63 删除公共字符串
首先,对于在线oj题目,我们可以只专注于结果,即只要最后打印出的结果符合题目要求即可.
修修修也
2024/04/01
1400
【牛客网】OR63 删除公共字符串
在字符串中删除特定的字符
题目:输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如,输入”They are students.”和”aeiou”,则删除之后的第一个字符串变成”Thy r stdnts.”。 首先我们考虑如何在字符串中删除一个字符。由于字符串的内存分配方式是连续分配的。我们从字符串当中删除一个字符,需要把后面所有的字符往前移动一个字节的位置。但如果每次删除都需要移动字符串后面的字符的话,对于一个长度为n的字符串而言,删除一个字符的时间复杂度为O(n)。而对于本题而言,有可能要删除的字符的个数是n,因此该
猿人谷
2018/01/17
11.3K0
【C语言】字符串函数详解
​ strcpy 函数是一个用于拷贝字符串的函数,即将一个字符串中的内容拷贝到另一个字符串中(会覆盖原字符串内容)。它的参数是两个指针,第一个指向的是拷贝字符串的目的地的起始位置,即要将字符串拷贝到什么地方;第二个指向的是要拷贝字符串的内容的起始位置,即需要拷贝的字符串。它的返回值是目标空间的起始位置。
利刃大大
2025/05/22
1800
【C语言】字符串函数详解
字符串与内存函数的介绍+模拟实现
C语言中对字符和字符串的处理很是繁琐,但是C语言本身是没有字符串类型的字符串通常存放在常量字符串或者字符数组中。 字符串常量适用于那些对它不做修改的字符串函数。
Yui_
2024/10/16
1210
字符串与内存函数的介绍+模拟实现
【C字符串函数】字符串函数和内存操作函数模拟实现(进阶版)
原因:在找到dest的‘\0’后,进行src的的一个字符的拷贝时将dest(其实也是src)的’\0’覆盖掉,追加将无法停下来
MicroFrank
2023/01/16
5110
初识C语言·字符(串)函数
这些就是C语言中专门做字符分类的函数了,从英文的角度来看是很好理解的,比如isspace就是
_lazy
2024/10/16
1230
初识C语言·字符(串)函数
库函数之字符函数与字符串函数(下)
这些函数在使用时,都是遇到’\0’,才停止他们的拷贝,追加,比较等操作 如果我们想要只操作其中的部分,就可以增加一个参数来实现. 由于功能参数等与前面的函数相似,本篇不做重点讲解.
初阶牛
2023/03/20
4880
库函数之字符函数与字符串函数(下)
【C语言】字符串函数+内存操作函数
Function of a function is Get the length of a string.
举杯邀明月
2023/04/12
1K0
【C语言】字符串函数+内存操作函数
【C语言】字符串函数、字符函数和内存操作函数
注意:(1)strlen函数返回的是在字符串中 ‘\0’ 前面出现的字符个数(不包 含 ‘\0’)
YoungMLet
2024/03/01
1690
【Nowcoder-BC146.添加逗号 -OR63.删除公共字符】
题目:对于一个较大的整数 N(1<=N<=2,000,000,000) 比如 980364535,我们常常需要一位一位数这个数字是几位数,但是如果在这个数字每三位加一个逗号,它会变得更加易于朗读。 因此,这个数字加上逗号成如下的模样:980,364,535请写一个程序完成这件事情。
YoungMLet
2024/03/01
1680
抽丝剥茧C语言(高阶)字符函数和字符串函数+练习
C语言中对字符和字符串的处理很是频繁,但是C语言本身是没有字符串类型的,字符串通常放在常量字符串中或者字符数组中。 字符串常量适用于那些对它不做修改的字符串函数。 注意:英文部分是网站上的资料 链接: cplusplus
有礼貌的灰绅士
2023/03/28
4070
抽丝剥茧C语言(高阶)字符函数和字符串函数+练习
【C语言】字符串函数strcpy&&strcat&&strcmp&&strstr的使⽤和模拟实现
记上节,我们学了字符串strlen的使用和三种模拟实现方法,本小节,阿森继续和你一起学习4个字符串函数:strcpy,strcat,strcmp,strstr的使用和他的模拟实现方法,学习这些库函数,可以更好的方便操作字符和字符串,文章干货满满,接下来我们就学习一下这些函数吧!
学习起来吧
2024/02/29
6840
【C语言】字符串函数strcpy&&strcat&&strcmp&&strstr的使⽤和模拟实现
C语言进阶(五)——字符串+内存函数的介绍
  C语言中对字符和字符串的处理很是频繁,但是C语言本身是没有字符串类型的,字符串通常放在常量字符串或者字符数组中。字符串常量适用于那些对他不做修改的字符串函数。
RAIN7
2021/08/11
6050
C语言——字符函数与字符串函数
C语言中有一系列的函数是专门做字符分类的,也就是一个字符是属于什么类型的字符的,而这些函数的使用的需要包含一个头文件<ctype.h>
迷迭所归处
2024/11/19
1410
C语言——字符函数与字符串函数
手把手教你玩转常用字符串函数(包含模拟实现)
关于函数定义的图片,本文均取自cplusplus.com - The C++ Resources Network
大海里的番茄
2024/01/19
1600
手把手教你玩转常用字符串函数(包含模拟实现)
【C语言】字符和字符串函数(2)
   我们之前学习的strcpy的作用是把源字符串拷贝到目标空间内,而且经过我们的模拟实现,我们也意识到它拷贝的时候会把目标空间的内容给替换了,我们可以来测试一下:
TANGLONG
2024/10/15
1780
【C语言】字符和字符串函数(2)
C语言----字符函数和字符串函数
在编程的过程中,我们要经常处理字符和字符串,为了方便操作字符和字符串,c语言标准库中提供的一系列库函数,接下来我们就开始学习与认识他们
Undoom
2024/09/23
2140
C语言----字符函数和字符串函数
字符函数和字符串函数
C语言有一些列函数用于对不同的字符进行分类,一个字符属于何种类型。以下函数都需要包含头文件 ctype.h。
技匠晓晨
2024/11/26
1770
字符函数和字符串函数
C语言: 详解常用的字符串函数(使用+模拟实现)
C语言中,字符串函数和字符函数的使用是很频繁的,如果我们能够熟练使用,能够帮助我们解决很多的字符问题。
青衫哥
2023/03/31
8490
C语言: 详解常用的字符串函数(使用+模拟实现)
【字符函数】strcpy函数(字符串复制函数)+strcat函数(字符串追加)+strcmp函数(字符串比较)【笔记】
strcpy函数用于拷贝字符串,即将一个字符串中的内容拷贝到另一个字符串中(会覆盖原字符串内容)。它的参数是两个指针
用户11367452
2024/11/21
2740
【字符函数】strcpy函数(字符串复制函数)+strcat函数(字符串追加)+strcmp函数(字符串比较)【笔记】
推荐阅读
相关推荐
【牛客网】OR63 删除公共字符串
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验