1111 WordReplace
#include<iostream>
#include<string>
using namespace std;
int main()
{
string sa,sb,s;
while(getline(cin,s))
{
getline(cin,sa);
getline(cin,sb);
int begin=0;
begin=s.find(sa,begin);
int l=sa.length();
while(begin!=-1)
{
s.replace(begin,l,sb);
begin=s.find(sa,begin);
}
cout<<s<<endl;
}
return 0;
}
重点:getline(),find(),replace()函数
1.一个有用的string IO操作:getling。这个函数接受两个参数:一个输入流对象和一个string对象。getline函数从输入流的下一行读取,并保存读取的内容到string中,但不包括换行符。和输入操作符不一样的是,getline并不忽略行开头的换行符。只要getline遇到换行符,即便它是输入的第一个字符,getline也将停止读入并返回。如果第一个字符就是换行符,则string参数将被置为空string。
getline函数将istream参数作为返回值,和输入操作符一样也把它用作判断条件。例如:
int main()
{
string line;
// read line at time until end-of-file
while (getline(cin, line))
cout << line << endl;
return 0;
}
由于line不含换行符,若要逐行输出需要自行添加。照常,用endl来输出一个换行符来刷新输出缓冲区。
注解:由于getline函数返回时丢弃换行符,换行符将不会存储在string对象中。
2.find()
- ////find函数返回类型 size_type
- string s("1a2b3c4d5e6f7g8h9i1a2b3c4d5e6f7g8ha9i");
- string flag;
- string::size_type position;
- //find 函数 返回jk 在s 中的下标位置
- position = s.find("jk");
- if (position != s.npos) //如果没找到,返回一个特别的标志c++中用npos表示,我这里npos取值是4294967295,
- {
- cout << "position is : " << position << endl;
- }
- else
- {
- cout << "Not found the flag" + flag;
- }
- //find 函数 返回flag 中任意字符 在s 中第一次出现的下标位置
- flag = "c";
- position = s.find_first_of(flag);
- cout << "s.find_first_of(flag) is : " << position << endl;
- //从字符串s 下标5开始,查找字符串b ,返回b 在s 中的下标
- position=s.find("b",5);
- cout<<"s.find(b,5) is : "<<position<<endl;
- //查找s 中flag 出现的所有位置。
- flag="a";
- position=0;
- int i=1;
- while((position=s.find_first_of(flag,position))!=string::npos)
- {
- //position=s.find_first_of(flag,position);
- cout<<"position "<<i<<" : "<<position<<endl;
- position++;
- i++;
- }
- //查找flag 中与s 第一个不匹配的位置
- flag="acb12389efgxyz789";
- position=flag.find_first_not_of (s);
- cout<<"flag.find_first_not_of (s) :"<<position<<endl;
- //反向查找,flag 在s 中最后出现的位置
- flag="3";
- position=s.rfind (flag);
- cout<<"s.rfind (flag) :"<<position<<endl;
- }
3.replace()函数
- basic_string::max_size
C++ replace()函数返回string 能放的最大元素个数。(不同于capacity)
- size _ type max _ size( ) const;
- basic_string <char>::size_type cap, max;
- cap = s.capacity ( );
- max = s.max_size ( ); // max=4294967294.
- basic_string::rfind
寻找给定的string。返回找到的第一个string 下标值;如果没找到则返回npos。
与find 不同的是:rfind 默认从npos 开始找。其他相同。
- basic_string::replace
将原string 中的元素或子串替换。返回替换后的string。
(1)用string 或C-string 代替操作string 中从 _Pos1 开始的 _Num1 个字符
- basic _ string& replace( size _ type _Pos1 ,
size _ type _Num1 , const value _ type* _Ptr );- basic _ string& replace(size _ type _Pos1 ,
size _ type _Num1 ,const basic _ string _Str );- string a,b;
- string s ( "AAAAAAAA" );
- string s1p ( "BBB" );
- const char* cs1p = "CCC" ;
- a = s.replace ( 1 , 3 , s1p ); // s= ” ABBBAAAA ”
- b = s.replace ( 5 , 3 , cs1p ); // s= ” ABBBACCC ”
(2)用C++ replace()函数中从 _Pos2 开始的 _Num2 个字符,代替操作string 中从 _Pos1 开始的 _Num1 个字符
用C-string 中的 _Num2 个字符,代替操作string 中从 _Pos1 开始的 _Num1 个字符
- basic _ string& replace( size _ type _Pos1 ,
size _ type _Num1 , const basic _ string& _Str ,- size _ type _Pos2 , size _ type );
- basic _ string& replace( size _ type _Pos1 , size _ type _Num1 ,
- const value _ type* _Ptr , size _ type _Num2 );
- string a, b;
- string s ( "AAAAAAAA" );
- string s2p ( "BBB" );
- const char* cs2p = "CCC";
- a = s.replace ( 1 , 3 , s2p , 1 , 2 ); // s= ” ABBAAAA ”
- b = s.replace ( 4 , 3 , cs2p , 1 ); // s= ” ABBAC ”
(3)用 _Count 个character _Ch , 代替操作string 中从 _Pos1 开始的 _Num1 个字符
- basic _ string& replace( size _ type _Pos1 , size _ type _Num1 ,
- size _ type _Count , value _ type _Ch );
- string result;
- string s ( "AAAAAAAA" );
- char ch = 'C';
- result = s.replace ( 1 , 3 , 4 , ch ); // s= ” ACCCCAAAA ”
(4)用string 或C-string ,代替操作string 中从 First0 到 Last0 的字符
- basic _ string&replace(iterator First0 ,iterator Last0 ,
const basic _ string& _Str );- basic _ string&replace(iterator First0 ,iterator _Last0 ,
const value _ type* _Ptr );- string s ( "AAAAAAAA" ); string s4p ( "BBB" );
- const char* cs4p = "CCC";
- basic_string<char>::iterator IterF0, IterL0;
- IterF0 = s.begin ( ); IterL0 = s.begin ( ) + 3;
- string a, b;
- a = s.replace ( IterF0 , IterL0 , s4p ); // s= ” BBBAAAAA ”
- b = s.replace ( IterF0 , IterL0 , cs4p ); // s= ” CCCAAAAA ”
(5)用C++ replace()函数中从 _Pos2 开始的 _Num2 个字符,代替操作string 中从 First0 到 Last0 的字符
用C-string 中的 _Num2 个字符,代替操作string 中从 First0 到 Last0 的字符
- basic _ string& replace( iterator _First0 , iterator _Last0 ,
- const value _ type* _Ptr , size _ type _Num2 );
- template<class InputIterator> basic _ string& replace(
- iterator _First0 , iterator _Last0 ,
- InputIterator _First , InputIterator _Last );
- IterF3 = s.begin ( ) + 1; IterL3 = s.begin ( ) + 3;
- IterF4 = s.begin ( ); IterL4 = s.begin ( ) + 2;
- a = s.replace ( IterF3 , IterL3 , IterF4 , IterL4 );
- b = s.replace ( IterF1 , IterL1 , cs5p , 4 );
(6)用 _Count 个character _Ch , 代替操作string 中从 First0 到 Last0 的字符
- basic _ string& replace( iterator _First0 , iterator _Last0 ,
- size _ type _Count , value _ type _Ch );
- a = s.replace ( IterF2 , IterL2 , 4 , ch );
- basic_string::swap
交换两个string。
- void swap( basic _ string& _Str );
- s1.swap ( s2 );
- basic_string::substr
返回从 _Off ( 下标)开始的 _Count 个字符组成的string
- basic _ string substr( size _ type _Off = 0,
size _ type _Count = npos ) const;- string s("I love you!") , sub;
- ssub=s.substr( ); // sub= ” I love you! ”
- ssub=s.substr(1); // sub= ” love you! ”
- ssub=s.substr(3,4); // sub= ” ove ”
1111 WordReplace的更多相关文章
- Entity Framework 6 Recipes 2nd Edition(11-11)译 -> 在LINQ中调用数据库函数
11-11. 在LINQ中调用数据库函数 问题 相要在一个LINQ 查询中调用数据库函数. 解决方案 假设有一个任命(Appointment )实体模型,如Figure 11-11.所示, 我们想要查 ...
- 【九度OJ】题目1111:单词替换
题目1111:单词替换 题目描述: 输入一个字符串,以回车结束(字符串长度<=100).该字符串由若干个单词组成,单词之间用一个空格隔开,所有单词区分大小写.现需要将其中的某个单词替换成另一个单 ...
- [转]Mybatis出现:无效的列类型: 1111 错误
原文地址:http://www.cnblogs.com/sdjnzqr/p/4304874.html 在使用Mybatis时,不同的xml配置文件,有的会提示:无效的列类型: 1111 比如这个sql ...
- BZOJ 1111: [POI2007]四进制的天平Wag
1111: [POI2007]四进制的天平Wag Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 223 Solved: 151[Submit][St ...
- Mybatis出现:无效的列类型: 1111 错误
在使用Mybatis时,不同的xml配置文件,有的会提示:无效的列类型: 1111 比如这个sql: update base.sys_person t set t.rybh=#{rybh},t.xm= ...
- csuoj 1111: 三家人
acm.csu.edu.cn/OnlineJudge/problem.php?id=1111 1111: 三家人 Time Limit: 1 Sec Memory Limit: 128 MBSubm ...
- ZOJ 1111 Poker Hands
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=1111 A poker hand consists of 5 ca ...
- hdu 1111 Secret Code
http://acm.hdu.edu.cn/showproblem.php?pid=1111 复数除法: #include <cstdio> #include <cstring> ...
- Luogu 1111 修复公路(最小生成树)
Luogu 1111 修复公路(最小生成树) Description A地区在地震过后,连接所有村庄的公路都造成了损坏而无法通车.政府派人修复这些公路. 给出A地区的村庄数N,和公路数M,公路是双向的 ...
随机推荐
- js的继承实现
1.原型链继承 1.创建父类对象2.创建子类函数对象3.将父类的实例对象赋值给子类的原型4.将子类的原型属性的构造函数设置为 子类本身 function Person(name) { this.nam ...
- PHP动态编译出现Cannot find autoconf的解决方法
wget http://ftp.gnu.org/gnu/m4/m4-1.4.9.tar.gz tar -zvxf m4-.tar.gz cd m4-/ ./configure && m ...
- nyoj135 取石子(二) Nimm博弈
思路:计算每堆石子的SG值,然后异或得到总的SG值,如果SG=0则输,否则赢. 每堆石子的SG值等于m%(n+1),可以自己推算一下. AC代码 #include <cstdio> #in ...
- 转 Caffe学习系列(9):运行caffe自带的两个简单例子
为了程序的简洁,在caffe中是不带练习数据的,因此需要自己去下载.但在caffe根目录下的data文件夹里,作者已经为我们编写好了下载数据的脚本文件,我们只需要联网,运行这些脚本文件就行了. 注意: ...
- 【Unity3D】Unity3D开发《我的世界》之二、创建一个立方体
转载请注明出处:http://www.cnblogs.com/shamoyuu/p/unity_minecraft_02.html 这一篇的内容比较简单,因为所有理论内容都在上一篇中讲到了.但有两点需 ...
- Python模拟登录成功与失败处理方式(不涉及前端)
任务说明: (1) 用户输入用户名,如不存在此用户不能登录: (2) 用户在输入密码时,如果连续输入三次错误,则该用户被锁定一段时间; (3) 用户被锁定一段时间后,可再次进行尝试登录: 程序使用库: ...
- Flex中的FusionCharts 3D饼图
1.3D饼图设计源码 <?xml version="1.0" encoding="utf-8"?> <s:Application xmlns: ...
- WebService之CXF注解之一(封装类)
Teacher.java: /** * @Title:Teacher.java * @Package:com.you.model * @Description:老师封装类 * @author:Youh ...
- RTSP协议分析
RTSP 协议分析 1.概述: RTSP(Real Time Streaming Protocol),实时流传输协议,是TCP/IP协议体系中的一个应用层协议,由哥伦比亚大学.网景和RealNetw ...
- Exception sending context initialized event to listener instance of class
1.错误描述 严重:Exception sending context initialized event to listener instance of class org.springframew ...