题目复制不太好看,我直接给截图了,如上:
究其本源,pta L1的题目主要侧重于对字符串处理的考察,可以说拿下字符串,pta L1的题目百分之八十五的部分基本上都不会难倒你了,所以要在做题的时候注意积累。这里是我的记忆存档处哈,不同的人见解可能不同,算法也各有千秋,望诸位轻踩。
我的AC代码给附在下面了,写了部分注释,大家可以参考一下,写写属于自己的那一份。
#include<bits/stdc++.h>
using namespace std;
int main()
{string str;getline(cin,str); //cin是正在读取的输入流,str是接收输入字符串的String变量的名称。 for(int i=0;i<=str.size();i++){if(str[i]=='6'){int count=0;for(int j=i;str[j]=='6';j++){count++; }if(count>3&&count<=9){str.replace(i,count,"9");/*replace目前最主要有这两种用法,一种是当前使用的这种replace(字符串起始坐标i,往后数几个字符count,"(用来替换的字符串9)") ;注意,算本身。 另一种是迭代器的替换replace(line.begin(),line.begin()+6,string);(将开始到第六个字符用string来替换,可以做减法确定有几个字符被改变)。 */ }if(count>9){str.replace(i,count,"27");}}}cout<<str<<endl;return 0;
}
*用法一:
用str替换指定字符串从起始位置pos开始长度为len的字符
string& replace (size_t pos, size_t len, const string& str);*用法二:
用str替换 迭代器起始位置 和 结束位置 的字符
string& replace (const_iterator i1, const_iterator i2, const string& str);