Intelligent IME HDU - 4287 字典树
题意:
给你m个字符串,每一个字符对应一个数字,如下:
2 : a, b, c 3 : d, e, f 4 : g, h, i 5 : j, k, l 6 : m, n, o 7 : p, q, r, s 8 : t, u, v 9 : w, x, y, z
输入n个数字串,问这个数字串可以对应几个字符串
比如ade这个字符串对应的数字串就是233
题解:
用这m个字符串建立一颗字典树,对于每一个节点维护一个变量val,他就代表(从树根到这个节点这一个数字串)有多少个对应的字符串
每次插入的时候记录一下最大值就完了
代码:
1 #include <iostream>
2 #include <cstdio>
3 #include <cstring>
4 #include <cstdlib>
5 #include <algorithm>
6 using namespace std;
7 typedef struct Trie* TrieNode;
8 char s[130];
9 char v[5005][10];
10 struct Trie
11 {
12 int val;
13 TrieNode next[8];
14 Trie()
15 {
16 val = 0;
17 memset(next,NULL,sizeof(next));
18 }
19 };
20
21 void inserts(TrieNode root,char ss[10])
22 {
23 TrieNode p = root; //建立的字典树是字符串对应的数字串
24 int len=strlen(ss);
25 for(int i=0;i<len;++i)
26 {
27 int temp=s[ss[i]];
28 if(p->next[temp]==NULL) p->next[temp]=new struct Trie();
29 p=p->next[temp];
30 }
31 p->val+=1;
32 }
33
34 int query(TrieNode root,char ss[10])
35 {
36 TrieNode p = root;
37 int len=strlen(ss);
38 for(int i=0;i<len;++i)
39 {
40 int temp=ss[i]-'0'-2;
41 if(p->next[temp]==NULL)
42 {
43 //printf("%d**\n",i);
44 return 0;
45 }
46 else
47 {
48 p=p->next[temp];
49 }
50 }
51 return p->val;
52 }
53
54 void Del(TrieNode root)
55 {
56 for(int i=0 ; i<8 ; ++i)
57 {
58 if(root->next[i])Del(root->next[i]);
59 }
60 delete(root);
61 }
62
63 int main()
64 {
65 s['a']=s['b']=s['c']=0;
66 s['d']=s['e']=s['f']=1;
67 s['g']=s['h']=s['i']=2;
68 s['j']=s['k']=s['l']=3;
69 s['m']=s['n']=s['o']=4;
70 s['p']=s['q']=s['r']=s['s']=5;
71 s['t']=s['u']=s['v']=6;
72 s['w']=s['x']=s['y']=s['z']=7;
73 int t,n,m;
74 char ss[10];
75 scanf("%d",&t);
76 while(t--)
77 {
78 TrieNode root = new struct Trie();
79 scanf("%d %d",&n,&m);
80 for(int i=0 ; i<n ; ++i)
81 {
82 scanf("%s",v[i]);
83 }
84 for(int i=0 ; i<m ; ++i)
85 {
86 scanf("%s",ss);
87 inserts(root,ss);
88 }
89 for(int i=0;i<n;++i)
90 {
91 printf("%d\n",query(root,v[i]));
92 }
93 Del(root);
94 }
95 return 0;
96 }
Intelligent IME HDU - 4287 字典树的更多相关文章
- HDU 5687 字典树插入查找删除
题目:http://acm.hdu.edu.cn/showproblem.php?pid=5687 2016百度之星资格赛C题,直接套用字典树,顺便巩固了一下自己对字典树的理解 #include< ...
- HDU 5384 字典树、AC自动机
题目:http://acm.hdu.edu.cn/showproblem.php?pid=5384 用字典树.AC自动机两种做法都可以做 #include<stdio.h> #includ ...
- hdu 2112(字典树+最短路)
HDU Today Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
- hdu 2072(字典树模板,set,map均可做)
地址:http://acm.hdu.edu.cn/showproblem.php?pid=2072 lily的好朋友xiaoou333最近很空,他想了一件没有什么意义的事情,就是统计一篇文章里不同单词 ...
- Chip Factory HDU - 5536 字典树(删除节点|增加节点)
题意: t组样例,对于每一组样例第一行输入一个n,下面在输入n个数 你需要从这n个数里面找出来三个数(设为x,y,z),找出来(x+y)^z(同样也可以(y+z)^1)的最大值 ("^&qu ...
- hdu 1251 字典树的应用
这道题看了大神的模板,直接用字典树提交的会爆内存,用stl 里的map有简单有快 #include <iostream> #include <map> #include < ...
- hdu 2896 字典树解法
#include <iostream> #include <cstring> #include <cstdio> #include <cstdlib> ...
- Repository HDU - 2846 字典树
题意:给出很多很多很多很多个 单词 类似搜索引擎一下 输入一个单词 判断有一个字符串包含这个单词 思路:字典树变体,把每个单词的后缀都扔字典树里面,这里要注意dd是一个单词 但是把d 和dd都放字典树 ...
- Phone List HDU - 1671 字典树
题意:给出一堆一组一组的数字 判断有没有哪一个是另外一个的前缀 思路:字典树 插入的同时进行判断 不过 当处理一组数字的时候 需要考虑的有两点1.是否包含了其他的序列2.是否被其他序列包含 刚开始 ...
随机推荐
- 一道有趣的golang排错题
很久没写博客了,不得不说go语言爱好者周刊是个宝贝,本来想随便看看打发时间的,没想到一下子给了我久违的灵感. go语言爱好者周刊78期出了一道非常有意思的题目. 我们来看看题目.先给出如下的代码: p ...
- 关于SSRF与CSRF漏洞的解释
目录 SSRF服务端请求伪造(外网访问内网) 1.SSRF形成原因 2.利用SSRF漏洞的目的 3.SSRF漏洞的用途 4.SSRF漏洞的特性 实例 5.如何挖掘SSRF漏洞 6.常用SSRF去做什么 ...
- WIN7系统没有USB驱动和以太网驱动如何操作
| 欢迎关注个人公众号 zclinux_note 第一时间获取关于linux使用的技巧.探索Linux的奥秘 | 今天在单位安装了一台win7纯净版,但是安装完成后发现usb没有反应,插上网 ...
- 【Oracle】sum(..) over(..)用法分析
今天再看sql优化详解的时候,提到了一个sum(..) over(..) 于是自己实验并在网上找了相关的一些文章来看 下面创建一张表: create sequence xulie increment ...
- Springboot之文件监控
背景:在实际环境部署构成中,由于特殊网络环境因素,有很多服务器之间的网络都是单向的,不能互相访问的,只有通过特定技术手段做到文件的单项摆渡,这就需要在两台服务器上分别写序列化程序和反序列化程序,这里不 ...
- VL02N发货过账BAPI
使用BAPI函数: BAPI_OUTB_DELIVERY_CONFIRM_DEC 进行delivery的发货过账,可能会有如此的需求,就是修改实际的发货日期.规划的GI.交货日期.装载日期.传输计划日 ...
- zabbix-server安装部署配置
zabbix-server安装部署配置 zabbixLinux安装部署安装脚本 1 一步一步部署 1.1 安装zabbix仓库源 这里安装阿里的zabbix仓库地址 选用zabbix版本3.4 rpm ...
- Django的数据库读写分离
Django的数据库读写分离 1.首先是配置数据库 在settings.py文件中增加多个数据库的配置: DATABASES = { 'default': { 'ENGINE': 'django.db ...
- scrapy框架的中间件
中间件的使用 作用:拦截所有的请求和响应 拦截请求:process_request拦截正常的请求,process_exception拦截异常的请求 篡改请求的头信息 def process_reque ...
- 【Android初级】利用startActivityForResult返回数据到前一个Activity(附源码+解析)
在Android里面,从一个Activity跳转到另一个Activity.再返回,前一个Activity默认是能够保存数据和状态的.但这次我想通过利用startActivityForResult达到相 ...