L1-101 别再来这么多猫娘了!(string类关键函数解决)

关键函数详解:

1.string类的find函数返回一个整数,表示查找的子串在字符串中首次出现的位置。如果找到子串,返回值是子串第一个字符在字符串中的索引位置,索引从0开始。如果没有找到子串,则返回string::npos,这是一个特殊的值,表示没有找到匹配项。string::npos是一个非常大的值,通常用作未找到的标记。

2.string类的replace(startPos, from.length(), to)

这里 startPos 是一个整数,表示要开始替换操作的位置。这个位置是之前通过find函数找到的子串"from"在字符串str中的起始索引。

from.length() 计算的是被替换子串"from"的长度。因为replace函数需要知道要替换多少字符。通过传递from.length()作为第二个参数,告诉函数从startPos开始的连续多少个字符需要被替换掉。

to 是要用来替换"from"的新的字符串。

cpp 复制代码
#include<iostream>
#include<cmath>
#include<algorithm>
#define rep(i,a,n) for(int i=a;i<=n;i++)
using namespace std;
signed main()
{
	ios::sync_with_stdio(false);    
	cin.tie(0);
	cout.tie(0);
	int n,k,cnt=0;
    cin>>n;
    string hex="<censored>";
    string tmp="*-*"; //<censored>本身也会成为屏蔽词,先替换成别的
    string str[110];
    string pas;
    cin.ignore();
    rep(i,1,n){
        getline(cin,str[i]);
    }
    cin>>k;
    cin.ignore();
    getline(cin,pas);
    //正确输入整段文本,
    rep(i,1,n){
        while(pas.find(str[i])!=string::npos){
            int last=pas.find(str[i]);
            pas.replace(pas.find(str[i]),str[i].length(),tmp);
            if(last==pas.find(str[i])) break;
            cnt++;
        }
    }
    while(pas.find(tmp)!=string::npos){
        pas.replace(pas.find(tmp),tmp.length(),hex);
    }
    if(cnt<k){
        cout<<pas<<'\n';
    }
    else cout<<cnt<<'\n'<<"He Xie Ni Quan Jia!";
	return 0;
}
注意避开的坑:

1.整数和整行文本输入时需要用cin.ignore()吸收换行符

2.<censored>本身也会成为屏蔽词,需要先替换成别的

3.避免陷入替换的无限循环导致超时

相关推荐
青春:一叶知秋20 分钟前
【C++】protobuf序列化与反序列化
开发语言·c++
Zhang~Ling2 小时前
C++ 红黑树封装:myset和mymap的底层实现
开发语言·数据结构·c++·算法
啦啦啦啦啦zzzz2 小时前
数据结构:堆排序
数据结构·c++·
原来是猿2 小时前
为什么 C++ 需要区分左值和右值?
开发语言·c++
珊瑚里的鱼2 小时前
C++的强制类型转换
android·开发语言·c++
星恒随风2 小时前
C++ 类和对象入门(二):默认成员函数、构造函数和析构函数详解
开发语言·c++·笔记·学习
一个不知名程序员www2 小时前
算法学习入门---算法题DAY5
c++·算法
牛油果子哥q3 小时前
【C++ this指针】C++ this指针深度精讲:this底层本质、存储位置、调用机制、const this指针、空指针调用、面试坑点与工程实战
开发语言·c++·面试
坚果派·白晓明3 小时前
[鸿蒙PC三方库移植适配] 使用 AtomCode + Skills 自动完成spdlog鸿蒙化适配
c++·华为·ai编程·harmonyos·skills·atomcode
小禹在努力3 小时前
brpc1.15问题实录:bthread_worker_count取Node CPU,K8s缩容引发线程数超限
c++·微服务·rpc