Background

一封好的情书需要撰写人全身心的投入。CYY同学看上了可爱的c**想对她表白,但却不知道自己写的情书是否能感动她,现在他带着情书请你来帮助他。

Description

为了帮助CYY,我们定义一个量化情书好坏的标准感动值。判断感动值的方法如下:

1.在情书的一句话中若含有给定词汇列表中的特定单词,则感动值加1,但每一单词在同一句话中出现多次感动值不叠加,不同单词不受影响。保证输入的单词不重复。

2.每句话以英文句号定界。

3.全文不区分大小写。

Input

第一行包含一个数字n,表示导致感动值提升的词汇列表中单词的数量,随后n行是给定单词,每行一个。保证单词只包含英文字母。

最后一行为情书正文,保证只包含以下几种字符: 英文字母、数字、空格、英文逗号、英文句号。

Output

一个数字g,表示情书带来的感动值。

这题先要读清题好吧 emm。

每一单词在同一句话中出现多次,感动值不增加.

这个同一句话就是严格的同一句话.就是遇到'.'才算一句话。

还记得我当年写情书的时候,那时候.....

我们用\(Trie\)树来解决这一个匹配问题.

"为什么不用\(AC\)自动机",

"我太弱了 ,用不来。

因此,我用了\(Trie\)树.

我们对\(n\)个串构建\(Trie\)树.

对于情书中的,遇到一个标点符号(题目中的,空格,逗号,句号)就查询一次.

判断是否重复出现,就标记某个单词之前出现在哪个句子中即可.

我们每遇到一个句号,就将句子数量\(++\)。

统计答案的时候判断\(val[u]==cnt\)即可。

如果相同,那他们就在同一个句子中,\(return \ false\)

PS:返回\(true\)的条件还有,这个单词在\(Trie\)树中出现过.

读入很毒瘤!!!

样例没出但是A了QWQ

代码

#include<cstdio>
#include<iostream>
#include<algorithm>
#define R register using namespace std; const int maxn=5008; inline void in(int &x)
{
int f=1;x=0;char s=getchar();
while(!isdigit(s)){if(s=='-')f=-1;s=getchar();}
while(isdigit(s)){x=x*10+s-'0';s=getchar();}
x*=f;
} int idx,val[maxn*15],ans,cnt=1,n,len; char tri[maxn*15][26],s[maxn]; inline void insert(R char *s,R int len)
{
R int u=0;
for(R int i=1;i<=len;i++)
{
R int v=s[i]-'a';
if(!tri[u][v])tri[u][v]=++idx;
u=tri[u][v];
}
val[u]=20011003;
} inline bool query(R char *s,R int len)
{
R int u=0;
for(R int i=1;i<=len;i++)
{
R int v=s[i]-'a';
if(!tri[u][v] or s[i]>'z' or s[i]<'a')
return false;
u=tri[u][v];
}
if(val[u]!=cnt and val[u])
{
val[u]=cnt;
return true;
}
return false;
} int main()
{
in(n);
char c;
for(R int i=1;i<=n;i++)
{
len=0;
while((c=getchar())!='\n' and c!=' ')
{
if(c>='A' and c<='Z')c=c-'A'+'a';
s[++len]=c;
}
insert(s,len);
}
len=0;
while((c=getchar())!=EOF)
{
if(c==' ' or c=='.' or c==',')
{
if(query(s,len))ans++;
len=0;
cnt=cnt+(c=='.');
continue;
}
if(c>='A' and c<='Z')c=c-'A'+'a';
s[++len]=c;
}
if(query(s,len)) ans++;
printf("%d",ans);
}

Trie树【p2264】情书的更多相关文章

  1. P2264 情书 Trie匹配

    \(\color{#0066ff}{题目描述}\) 为了帮助CYY,我们定义一个量化情书好坏的标准感动值.判断感动值的方法如下: 1.在情书的一句话中若含有给定词汇列表中的特定单词,则感动值加1,但每 ...

  2. Trie树入门

    Trie树入门 貌似很多人会认为\(Trie\)是字符串类型,但是这是数据结构!!!. 详情见度娘 下面开始进入正题. PS:本文章所有代码未经编译,有错误还请大家指出. 引入 先来看一个问题 ​ 给 ...

  3. 基于trie树做一个ac自动机

    基于trie树做一个ac自动机 #!/usr/bin/python # -*- coding: utf-8 -*- class Node: def __init__(self): self.value ...

  4. 基于trie树的具有联想功能的文本编辑器

    之前的软件设计与开发实践课程中,自己构思的大作业题目.做的具有核心功能,但是还欠缺边边角角的小功能和持久化数据结构,先放出来,有机会一点点改.github:https://github.com/chu ...

  5. hihocoder-1014 Trie树

    hihocoder 1014 : Trie树 link: https://hihocoder.com/problemset/problem/1014 题意: 实现Trie树,实现对单词的快速统计. # ...

  6. 洛谷P2412 查单词 [trie树 RMQ]

    题目背景 滚粗了的HansBug在收拾旧英语书,然而他发现了什么奇妙的东西. 题目描述 udp2.T3如果遇到相同的字符串,输出后面的 蒟蒻HansBug在一本英语书里面找到了一个单词表,包含N个单词 ...

  7. 通过trie树实现单词自动补全

    /** * 实现单词补全功能 */ #include <stdio.h> #include <stdlib.h> #include <string.h> #incl ...

  8. #1014 Trie树

    本题主要是求构造一棵Trie树,即词典树用于统计单词. C#代码如下: using System; using System.Collections.Generic; using System.Lin ...

  9. Trie树-字典查找

    描述 小Hi和小Ho是一对好朋友,出生在信息化社会的他们对编程产生了莫大的兴趣,他们约定好互相帮助,在编程的学习道路上一同前进. 这一天,他们遇到了一本词典,于是小Hi就向小Ho提出了那个经典的问题: ...

随机推荐

  1. 【BZOJ3453】XLkxc [拉格朗日插值法]

    XLkxc Time Limit: 20 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description 给定 k,a,n,d,p f(i ...

  2. 使用.net core abp framework

    abp是一个有用的框架,包含许多功能,可以用来作为脚手架. 直接在官方网站上输入相应的工程名称,选择对应的版本就会下载对应的版本..net core 版本的可以使用后端框架部分来做api,包含了常用框 ...

  3. 【洛谷 P2042】 [NOI2005]维护数列(自闭记第一期)

    题目链接 首先,这题我是没A的..太毒瘤了 题目本身不难,都是\(Splay\)的基操,但是细节真的容易挂. 调了好久自闭了,果断放弃.. 希望本节目停更. 放上最终版本 #include <c ...

  4. 如何用js自己实现Animate运动函数

    js运动是我们学习js必不可少的研究部分,首先我们要知道js的运动其实仅仅是不断改变元素的某个属性值而已,比如不断改变一个绝对定位div的left值,那么你看到的效果就是这个div不断的向右边运动,那 ...

  5. Html5_sessionStrong和localStorage的灵活使用

    谈谈这两个属性sessionStrong和localStorage是Html5新增点属性,用来记录一些数据在浏览器. 两者的区别sessionStrong存储的数据是暂时的,浏览器关掉后,存储下来的数 ...

  6. adb操作指令大全

    adb是什么?:adb的全称为Android Debug Bridge,就是起到调试桥的作用.通过adb我们可以在Eclipse中方面通过DDMS来调试android程序,说白了就是debug工具.a ...

  7. kaggle比赛之悟

    一.模型与特征哪个重要? 参与Sberbank Russian Housing Market比赛,一开始使用sklearn的岭回归函数Ridge(),残差值一直是0.37左右,然后同样的特征又使用了X ...

  8. 计算机网络课设之基于UDP协议的简易聊天机器人

    前言:2017年6月份计算机网络的课设任务,在同学的帮助和自学下基本搞懂了,基于UDP协议的基本聊天的实现方法.实现起来很简单,原理也很简单,主要是由于老师必须要求使用C语言来写,所以特别麻烦,而且C ...

  9. js原生读取json

    function showJson(){ var test; if(window.XMLHttpRequest){ test = new XMLHttpRequest(); }else if(wind ...

  10. Python脚本 - 查询磁盘的读写次数信息

    测试系统为:Centos 6.7 Python版本为: 3.6.4 脚本功能:查看指定磁盘的读写及时间等相关信息 #!/usr/bin/env python3 from collections imp ...