九度OJ-题目1168:字符串的查找删除-string的使用(转)
来源:互联网 发布:java 两个类互相引用 编辑:程序博客网 时间:2024/05/21 07:55
題目链接:http://ac.jobdu.com/problem.php?pid=1168
题目描述:
给定一个短字符串(不含空格),再给定若干字符串,在这些字符串中删除所含有的短字符串。
输入:
输入只有1组数据。
输入一个短字符串(不含空格),再输入若干字符串直到文件结束为止。
输出:
删除输入的短字符串(不区分大小写)并去掉空格,输出。
样例输入:
in#include int main(){printf(" Hi ");}
样例输出:
#cludetma(){prtf("Hi");}
提示:
注:将字符串中的In、IN、iN、in删除。
AC代码:
#include <stdio.h>#include <string>#include <iostream>#include <ctype.h>using namespace std;void test_1(){ char str[101]; gets(str); string a = str;//将短字符串保存在a中; for(int i = 0;i< a.size();i++){ a[i] = tolower(a[i]);//将短字符串转为小写; } while(gets(str))//输入长字符串 { string b = str,c = b;//将长字符串保存在b,c中,之所以要用到两个临时字符串,因为有一个必须全部转为小写;见后面的代码 for(int i = 0;i<b.size();i++){ b[i] = tolower(b[i]);//将长字符串转为小写 } int index = b.find(a,0);//在长字符串中查找a的开始下标; while(index!=string::npos)//find的返回,如果没有找到,返回npos { c.erase(index,a.size()); b.erase(index,a.size()); index = b.find(a,index);//从index开始继续查找 } //上面已经删除了短字符串了,下面来删除空格 index = c.find(' ',0); while(index!=string::npos){ c.erase(index,1); index = c.find(' ',index); } cout<<c<<endl; }}int main() { test_1(); return 0;}
思想:这里需要在一个很长的字符串中找到指定的字符串,并将其去除,然后还要去掉空格,看清楚是空格,为了方便处理,我们将短字符串转为小写,那么相应的长字符也要转为小写才能找到相应的位置,这里要注意,长字符串转小写只是为了定位要删除的字符串开始下标,因此对于那些不需要删除且本身就是大写的字符就不需要转换,所以,我们应该讲将长字符串做一个备份,提供删除,见代码:
代码第20行中index!=string::npos,这里要注意,find函数的返回情况,没找到相应的子串便返回的是npos,
string还有很多函数,可以参考C/C++中字符串String及字符操作方法
转载自:http://www.cnblogs.com/numen-fan/p/6519800.html
阅读全文
0 0
- 九度OJ-题目1168:字符串的查找删除-string的使用(转)
- 九度OJ 题目1168:字符串的查找删除
- 九度oj题目1168:字符串的查找删除
- 九度OJ 1168:字符串的查找删除 (查找)
- 九度oj 题目1177:查找--string的替换、删除、反转
- 九度-1168 字符串的查找删除
- 天勤OJ 题目1064: 字符串的查找删除
- 九度oj 题目1105:字符串的反码(string的操作)
- 题目1168:字符串的查找删除
- 题目1168:字符串的查找删除
- Jobdu题目1168:字符串的查找删除
- Jobdu 题目1168:字符串的查找删除
- 题目1168:字符串的查找删除
- 题目1168:字符串的查找删除
- 题目1168:字符串的查找删除
- 题目1168:字符串的查找删除
- 题目1168:字符串的查找删除
- 九度oj 题目1174:查找第K小数(sort的使用)
- 设计模式简介
- BZOJ 1087: [SCOI2005]互不侵犯King 状态压缩 题解
- IAR下STM32F103 Boot + APP的编程
- Python NLTK等环境配置安装
- Linux 关闭系统时间同步-timedatectl的使用
- 九度OJ-题目1168:字符串的查找删除-string的使用(转)
- 【OpenCV入门教程之一】 安装OpenCV:OpenCV 3.0、OpenCV 2.4.8、OpenCV 2.4.9 +VS 开发环境配置
- 音频重采样
- android 通过uri获取bitmap图片并压缩
- 点击图片,图片src重新加载(用于图片验证码)
- 3.1 Git Branching
- 各种有趣的 ARKit 展示:金发美女乱跳、怪兽来袭等
- 图片本身加上圆角
- java缓存技术的介绍