注意:图中内容与题目无关,如无法看到图片不影响解题
因此你的工作是实现一个审查内容的代码,用于对 AI 生成的内容的初步审定。更具体地说,你会得到一段由大小写字母、数字、空格及 ASCII 码范围内的标点符号的文字,以及若干个违禁词以及警告阈值,你需要首先检查内容里有多少违禁词,如果少于阈值个,则简单地将违禁词替换为<censored>
;如果大于等于阈值个,则直接输出一段警告并输出有几个违禁词。
输入格式:
输入第一行是一个正整数 N (1≤N≤100),表示违禁词的数量。接下来的 N 行,每行一个长度不超过 10 的、只包含大小写字母、数字及 ASCII 码范围内的标点符号的单词,表示应当屏蔽的违禁词。
然后的一行是一个非负整数 k (0≤k≤100),表示违禁词的阈值。
最后是一行不超过 5000 个字符的字符串,表示需要检查的文字。
从左到右处理文本,违禁词则按照输入顺序依次处理;对于有重叠的情况,无论计数还是替换,查找完成后从违禁词末尾继续处理。
输出格式:
如果违禁词数量小于阈值,则输出替换后的文本;否则先输出一行一个数字,表示违禁词的数量,然后输出He Xie Ni Quan Jia!
。
易错点:
1.一段由大小写字母、数字、空格及 ASCII 码范围内的标点符号的文字。
说明要用getline输入并且吃掉空格才能正确读入。
2.从左到右处理文本,违禁词则按照输入顺序依次处理。
要按照输入顺序把字符串找过一遍了之后再去判断下个违禁词。
3.如果违禁词数量小于阈值,则输出替换后的文本。
最后才输出,所以不能一开始就将替换词插入,如果有违禁词为“cen”之类的就会乱码。
4.一段由大小写字母、数字、空格及 ASCII 码范围内的标点符号的文字。
占位符不能是单个标点符号,不能包括数字字母。
5.如果违禁词小于阈值,直接输出文本,否则输出违禁词数和“He Xie Ni Quan Jia!";
考察对字符串操作的熟悉程度,大体分数好拿,细节有点多。
会用erase 、insert 、find函数会舒服很多。
代码:
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1e6+10;
string a[105];
int main()
{
int n,m;
cin>>n;
for(int i=1;i<=n;i++)cin>>a[i];
cin>>m;
string s;
getchar();
getline(cin,s);
int cnt=0;
for(int i=1;i<=n;i++)
{
while(s.find(a[i])!=-1)
{
int pos=s.find(a[i]);
s.erase(pos,a[i].size());
s.insert(pos,"++");
cnt++;
}
}
if(cnt<m)
{
while (s.find("++")!=-1)
{
int pos=s.find("++");
s.erase(pos,2);
s.insert(pos,"<censored>");
}
cout<<s;
}else
{
cout<<cnt<<"\n";
cout<<"He Xie Ni Quan Jia!\n";
}
}