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

代码

  1. #include<cstdio>
  2. #include<iostream>
  3. #include<algorithm>
  4. #define R register
  5. using namespace std;
  6. const int maxn=5008;
  7. inline void in(int &x)
  8. {
  9. int f=1;x=0;char s=getchar();
  10. while(!isdigit(s)){if(s=='-')f=-1;s=getchar();}
  11. while(isdigit(s)){x=x*10+s-'0';s=getchar();}
  12. x*=f;
  13. }
  14. int idx,val[maxn*15],ans,cnt=1,n,len;
  15. char tri[maxn*15][26],s[maxn];
  16. inline void insert(R char *s,R int len)
  17. {
  18. R int u=0;
  19. for(R int i=1;i<=len;i++)
  20. {
  21. R int v=s[i]-'a';
  22. if(!tri[u][v])tri[u][v]=++idx;
  23. u=tri[u][v];
  24. }
  25. val[u]=20011003;
  26. }
  27. inline bool query(R char *s,R int len)
  28. {
  29. R int u=0;
  30. for(R int i=1;i<=len;i++)
  31. {
  32. R int v=s[i]-'a';
  33. if(!tri[u][v] or s[i]>'z' or s[i]<'a')
  34. return false;
  35. u=tri[u][v];
  36. }
  37. if(val[u]!=cnt and val[u])
  38. {
  39. val[u]=cnt;
  40. return true;
  41. }
  42. return false;
  43. }
  44. int main()
  45. {
  46. in(n);
  47. char c;
  48. for(R int i=1;i<=n;i++)
  49. {
  50. len=0;
  51. while((c=getchar())!='\n' and c!=' ')
  52. {
  53. if(c>='A' and c<='Z')c=c-'A'+'a';
  54. s[++len]=c;
  55. }
  56. insert(s,len);
  57. }
  58. len=0;
  59. while((c=getchar())!=EOF)
  60. {
  61. if(c==' ' or c=='.' or c==',')
  62. {
  63. if(query(s,len))ans++;
  64. len=0;
  65. cnt=cnt+(c=='.');
  66. continue;
  67. }
  68. if(c>='A' and c<='Z')c=c-'A'+'a';
  69. s[++len]=c;
  70. }
  71. if(query(s,len)) ans++;
  72. printf("%d",ans);
  73. }

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. HDU 5643 King's Game | 约瑟夫环变形

    经典约瑟夫环 }; ; i<=n; i++) { f[i] = (f[i-] + k) % i; } 变形:k是变化的 #include <iostream> #include &l ...

  2. [uva11137]立方数之和·简单dp

    小水题再来一发 给定一个正整数n<=1e4,求将n写成若干个正整数立方和的方法数 典型的多阶段模型 f[i][j]表示当前用到1~i的数,累计和为j的方案数. #include<cstdi ...

  3. 省队集训 Day1 残缺的字符串

    [题目大意] 双串带通配符匹配. $|S|, |T| \leq 5 * 10^5$ TL: 2s [题解] 参考bzoj 4503 可以设计如下函数 A[i] * B[i] * (A[i] - B[i ...

  4. 「6月雅礼集训 2017 Day11」tree

    [题目大意] 给出一棵带权树,有两类点,一类黑点,一类白点. 求切断黑点和白点间路径的最小代价. $n \leq 10^5$ [题解] 直接最小割能过..但是树形dp明显更好写 设$f_{x,0/1/ ...

  5. [BZOJ1177][BZOJ1178][BZOJ1179]APIO2009解题报告

    抱着好奇心态去开始做APIO的往年试题感受一下难度 Oil Description 采油区域 Siruseri政府决定将石油资源丰富的Navalur省的土地拍卖给私人承包商以建立油井.被拍卖的整块土地 ...

  6. python初步学习-查看文档及数据类型转换

    学会查看文档 python最权威的文档就是官方文档,因此,我们要学会查看官方文档.而在python解释器中,help() 命令就可以很权威的查看官方文档. 因此,我们要学会使用 help() 命令. ...

  7. aircrack加reaver破解带有wps的wifi

    最近心血来潮,想把小区里的无线信号测试个遍.基于目前大多数路由器都支持wps,想必各位基友们都知道aircrack和reaver这 两个工具,实属破解pin码,杀人越货,居家旅行之必备良药.像以前跑r ...

  8. frp 使用入门

    1.下载安装对应系统版本 https://github.com/fatedier/frp/releases/ 2.将下载的frp移动到系统软件目录 mv frp/ /usr/local 3.配置frp ...

  9. Django 1.10中文文档-第一个应用Part6-静态文件

    本教程上接Part5 .前面已经建立一个网页投票应用并且测试通过,现在主要讲述如何添加样式表和图片. 除由服务器生成的HTML文件外,网页应用一般还需要提供其它必要的文件——比如图片.JavaScri ...

  10. python基础===discover函数介绍

    discover(start_dir,pattern='test*.py',top_level_dir=None) 找到指定目录下所有测试模块,并可递归查到子目录下的测试木块,只有匹配到的文件名才会被 ...