【2018年宁波市小学组】文明社会(culture)

9 篇文章 0 订阅
1 篇文章 0 订阅

【2018年宁波市小学组】文明社会(culture)

题目描述
党的十八大提出,倡导富强、民主、文明、和谐,倡导自由、平等、公正、法治,倡导爱国、敬业、诚信、友善,积极培育和践行社会主义核心价值观。富强、民
主、文明、和谐是国家层面的价值目标,自由、平等、公正、法治是社会层面的价值取向,爱国、敬业、诚信、友善是公民个人层面的价值准则,这 24 个字是社会主义核心价值观的基本内容。
但是在互联网上,会有一些不文明的人发送不文明的言论。我们的目的,就是要自动过滤并且识别这些言论。
给出一个字符串 S,表示那些可能不文明的言论。再给出一个字典 T,包含了 n条违规的用语,T[1], T[2], …, T[n]。要在 S 中添加最少的*,使得只要违规用语T[i]在 S 中出现,就得在每个 T[i]的字符之间添加*。
比如说 S=aaabbssss,T[1]=abb,T[2]=bbss。那么最后的符合规定的 S’就为aaabbssss。其中 abb 在第 3 到第 5 个字符之间出现,bbss 在第 4 到第 7个字符出现。数据保证字符串 S 不包括字符‘*’,且 T[i]的长度一定大于 1。其中|S|≤1000,n≤10,1<|T[i]| ≤100;|S|表示 S 字符串的长度,|T[i]|表示 T[i]字符串的长度。

输入
输入一共有 n+2 行,第一行为 S。第二行为 n(一共有几个违规用语)。接下来 n 行每行一个字符串表示违规用语 T[i]。

输出
输出共一行,即合格的字符串 S’。

样例输入
样例输入1
aaabbssss
2
abb
bbss
样例输入2
aabbbccbdd
3
aa
bb
cc

样例输出
样例输出1
aaabbssss
样例输出2
aabbbccbdd

这题题目大意就是说让你在一条场的字符串中找出一些短字符串,并在其中添加号。本题中如果有重复的字符串都只添加一个,比如aaabbssss将字符串abb、bbss中间添加的结果是aaabbssss而不是aaab**bssss。看完题目后你一定会想用枚举求,全用枚举其实是可以过的。
我们枚举要先枚长的字符串上的每个位,然后枚举几个短字符的可能,相信大家在以前的学习中都已经学过查找字符串了。如果匹配就在开一个循环把这几个数标记起来(提示:最后一个不用标记)。最后输出,如果标记了,就在这个字符后面加上*号,一起输出。

#include<bits/stdc++.h>
using namespace std;
char a[1001];
char dis[11][101];
int ch[11],b[1001];
int main()
{
	freopen("culture.in","r",stdin);
	freopen("culture.out","w",stdout);
	int n;
	scanf("%s\n",a+1);
	scanf("%d",&n);
	for(int i=1;i<=n;i++){scanf("%s",dis[i]+1);ch[i]=strlen(dis[i]+1);}
	int m=strlen(a+1);
	for(int i=1;i<=m;i++)
	{
		for(int j=1;j<=n;j++)
		{
			bool tf=true;
			for(int k=i;k<=i+ch[j]-1;k++)
			{
				if(dis[j][k-i+1]!=a[k])
				{
					tf=false;break;
				}
			}
			if(tf==true)
			{
				for(int k=i;k<i+ch[j]-1;k++)
					b[k]=1;
			}
		}
	}
	for(int i=1;i<=m;i++)
	{
		printf("%c",a[i]);
		if(b[i]==1)printf("*");
	}
	return 0;
}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值