C++ 删除字符串的两种实现方式

时间:2021-08-11 07:11:47

C++实现删除给定字符串的给定字符串思路主要有这么几种实现方式:

1.KMP算法
2.用STL的string的 find,然后用erase
3.用C的strstr找到字串位置,然后用strncpy写到新串中
4.用boost库,用正则表达式

测试过的完整代码:

第一种方法:

#include<iostream>
#include <string>
using namespace std; void deletestr(const char *str, const char* sub_str, char *result); int main()
{
char str[100],sub[100];
cin>>str;
cin>>sub;
char result;
deletestr(str,sub,&result);
return 0;
} void deletestr(const char *str, const char* sub_str, char *result)
{
int sublen = 0; //获得子串的长度
const char *t = sub_str;
while(*t++ != '\0')
{
sublen++;
} int pos = 0;
int pp = 0;
int repos = 0; // 结果子串的索引
while(*(str + pos) != '\0')
{
char t = *(str + pos);
if(t == *(sub_str + pp)) // 重复子串起始位置
{
*(result + repos) = t;
repos++; if(pp < sublen - 1) // 还未完全重复
{
pp++;
}
else if(pp == sublen - 1) // 完全重复了
{
pp = 0;
repos -= sublen; // 回溯下标位置
}
}
else{ // 不是一样的字符
*(result + repos) = t;
repos++;
}
pos++;
}
*(result + repos) = '\0';
cout<<result<<endl;
}

第二种方法,用STL

个人感觉很简单方便

#include<iostream>
#include <string>
using namespace std; void deletesub(string &str,const string &sub,int n);
int main()
{
string str,sub;
cin>>str;
cin>>sub;
int n=sub.size();
deletesub(str,sub,n);
return 0;
}
void deletesub(string &str,const string &sub,int n)
{
int m,flag=0,num=0; //num是子串出现的次数
while(flag==0)
{
m=str.find(sub);
if(m<0)
flag=1;
else
{
str.erase(m,n); //删除子串
num++;
}
}
// cout<<num<<endl; //子串出现的次数
cout<<str<<endl; // 输出删除后的字符串
}

C++ 删除字符串的两种实现方式的更多相关文章

  1. spring接收json字符串的两种方式

    一.前言 前几天遇到一个问题,前端H5调用我的springboot一个接口(post方式,@RequestParameter接收参数),传入的参数接收不到.自己测试接口时使用postman的form- ...

  2. C语言中存储多个字符串的两种方式

    C语言中存储多个字符串的两种方式 方式一    二维字符串数组 声明: char name[][] = { "Justinian", "Momo", &quot ...

  3. Java使用SFTP和FTP两种连接方式实现对服务器的上传下载 【我改】

    []如何区分是需要使用SFTP还是FTP? []我觉得: 1.看是否已知私钥. SFTP 和 FTP 最主要的区别就是 SFTP 有私钥,也就是在创建连接对象时,SFTP 除了用户名和密码外还需要知道 ...

  4. 巨蟒python全栈开发数据库前端6&colon;事件onclick的两种绑定方式&amp&semi;&amp&semi;onblur和onfocus事件&amp&semi;&amp&semi;window&period;onload解释&amp&semi;&amp&semi;小米商城讲解

    1.回顾上节内容(JavaScript) 一.JavaScript概述 1.ECMAScript和JavaScript的关系 2.ECMAScript的历史 3.JavaScript是一门前后端都可以 ...

  5. Android中Fragment与Activity之间的交互(两种实现方式)

    (未给Fragment的布局设置BackGound) 之前关于Android中Fragment的概念以及创建方式,我专门写了一篇博文<Android中Fragment的两种创建方式>,就如 ...

  6. Redis两种持久化方式&lpar;RDB&amp&semi;AOF&rpar;

    爬虫和转载请注明原文地址;博客园蜗牛:http://www.cnblogs.com/tdws/p/5754706.html Redis所需内存 超过可用内存怎么办 Redis修改数据多线程并发—Red ...

  7. 【Visual Lisp】两种出错处理方式

    两种出错处理方式:一种是对出错函数进行重定义,一种是对错误进行捕捉处理. ;;============================================================= ...

  8. 两种include方式及filter中的dispatcher解析

    两种include方式 我自己写了一个original.jsp,另外有一个includedPage.jsp,我想在original.jsp中把includedPage.jsp引进来有两种方式: 1.& ...

  9. PlaceHolder的两种实现方式

    placeholder属性是HTML5 中为input添加的.在input上提供一个占位符,文字形式展示输入字段预期值的提示信息(hint),该字段会在输入为空时显示. 如 <input typ ...

随机推荐

  1. &lbrack;转&rsqb;在Windows中配置Rsync同步

    在Windows中配置Rsync同步 Rsync是一款不错的文件免费同步软件,可以镜像保存整个目录树和文件系统,同 时保持原来文件的权限.时间.软硬链接.第一次同步时 rsync 会复制全部内容,下次 ...

  2. webrtc学习———记录三:mediaStreamTrack

    参考: https://developer.mozilla.org/en-US/docs/Web/API/MediaStreamTrack 转自http://c.tieba.baidu.com/p/3 ...

  3. HTML5 History对象,Javascript修改地址栏而不刷新页面(二)

    一.实例说明: $('#btnOne').click(function () { var stateObject = { id: 1 }; var title = "本地首页"; ...

  4. windows internal读书笔记

    程序:指一个静态的指令序列,而进程则是一个容器,其中包含了当执行一个程序特定实例时所用到的各种资源.

  5. ecstore后台规格超过一定数量保存丢失

    问题描述: 后台规格超过一定数量保存丢失,规格新增不了,删除出问题等不正常情况. 解决方法: 经过波波的不懈努力和日夜冥想终于破了.分析其原因就是因为多个规格组合生成的表单域太多,与php.ini配置 ...

  6. RabbitQM使用笔记

    一:安装  and  卸载 curl -s https://packagecloud.io/install/repositories/rabbitmq/rabbitmq-server/script.r ...

  7. IDEWorkspaceChecks&period;plist文件是干什么用的?

    在提交PR的时候,无意间发现了在xcworkspace/xcshareddata中多了一个名为IDEWorkspaceChecks.plist的文件.自己并没有手动创建此文件,在网上查了一下,最终对其 ...

  8. Web应用程序架构的比较

    架构 技术优势 技术挑战 团队优势 团队挑战 单体 低延时 开发简单 没有重复的模型/验证 伸缩 由于代码库过大引起的复杂度 特性内沟通的开销低 失败的恐惧 特性间沟通的开销大 前端+后端 能够单独扩 ...

  9. 剑指Offer&lowbar;编程题&lowbar;1

    题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数.   class Sol ...

  10. poj 2175 费用流消圈

    题意抽象出来就是给了一个费用流的残存网络,判断该方案是不是最优方案,如果不是,还要求给出一个更优方案. 在给定残存网络上检查是否存在负环即可判断是否最优. 沿负环增广一轮即可得到更优方案. 考虑到制作 ...