HDU 1298 T9 ( 字典树 )
题意 : 给你 w 个单词以及他们的频率,现在给出模拟 9 键打字的一串数字,要你在其模拟打字的过程中给出不同长度的提示词,出现的提示词应当是之前频率最高的,当然提示词不需要完整的,也可以是 w 个单词出现最多次数的前缀。
分析 : 利用字典树存储这 w 个单词,然后给每一个结点的权值赋上其单词出现频率,接下来的工作就简单多了,只要暴力枚举模拟输入的数字键盘可能产生的单词组合,然后保存频率最高的那个即可!
#include<string.h> #include<stdio.h> #include<malloc.h> #include<iostream> #include<algorithm> #include<map> using namespace std; ; , n, m; const int INF = 0x3f3f3f3f; ]{ ///模拟数字键盘,因为是从2开始,所以0和1都赋值上一个'@'代表空 {'@','@','@','@','@'}, {'@','@','@','@','@'}, {'a','b','c','@','@'}, {'d','e','f','@','@'}, {'g','h','i','@','@'}, {'j','k','l','@','@'}, {'m','n','o','@','@'}, {'p','q','r','s','@'}, {'t','u','v','@','@'}, {'w','x','y','z','@'} }; struct Trie { Trie *Next[maxn]; int v; inline void init(const int val){ this->v = val; ; i<maxn; i++) this->Next[i] = NULL; } }; Trie *root; void CreateTrie(char *str, int val) { int len = strlen(str); Trie *p = root, *tmp; ; i<len; i++){ int idx = str[i]-'a'; if(p->Next[idx] == NULL){ tmp = (Trie *)malloc(sizeof(Trie)); tmp->init(val); p->Next[idx] = tmp; }else (p->Next[idx]->v) += val;///赋上频率权值 p = p->Next[idx]; } } inline void DelTrie(Trie *T) { if(T == NULL) return ; ; i<maxn; i++){ if(T->Next[i] != NULL) DelTrie(T->Next[i]); } free(T); return ; } ], ans[], now[]; int tmp, MaxVal; void DFS(int pos, int len, Trie *NOD) { if(pos == len){///递归出口,看看频率是否更优,更新答案 if(NOD->v > MaxVal){ strcpy(ans, now); MaxVal = NOD->v; } return ; } '; ; mp[idx][i]!='@'; i++){///枚举这个数字建的所有字母,遇到'@'结束 int id = mp[idx][i] - 'a'; if(NOD->Next[id]){ ///如果字典树关于这个字母的节点不为空的话,则进一步搜索 now[pos] = mp[idx][i];///now是保存一下暂时现在构造出来的字符串,以便更新 now[pos+] = '\0'; DFS(pos+, len, NOD->Next[id]);///进一步搜索 } } } int main(void) { int nCase; scanf("%d", &nCase); ; Case<=nCase; Case++){ root = (Trie *)malloc(sizeof(Trie)); root->init(); scanf("%d", &n); int tmpVal; ; i<n; i++){ scanf("%s %d", str, &tmpVal); CreateTrie(str, tmpVal); } printf("Scenario #%d:\n", Case); scanf("%d", &m); ; i<m; i++){ scanf("%s", str); int len = strlen(str); ; j<len; j++){///枚举长度 MaxVal = -INF; DFS(, j, root); if(MaxVal == -INF) puts("MANUALLY"); else puts(ans); } puts(""); }puts(""); DelTrie(root); } ; }
HDU 1298 T9 ( 字典树 )的更多相关文章
- HDU 1298 T9 字典树+DFS
必须要批评下自己了,首先就是这个题目的迟疑不定,去年做字典树的时候就碰到这个题目了,当时没什么好的想法,就暂时搁置了,其实想法应该有很多,只是居然没想到. 同样都是对单词进行建树,并插入可能值,但是拨 ...
- hdu 1298 T9(特里+DFS)
pid=1298" target="_blank" style="">题目连接:hdu 1298 T9 题目大意:模拟手机打字的猜想功能.依据概 ...
- HDU 1298 T9【字典树增加||查询】
任意门:http://acm.hdu.edu.cn/showproblem.php?pid=1298 T9 Time Limit: 2000/1000 MS (Java/Others) Memo ...
- HDU 1298 T9(字典树+dfs)
http://acm.hdu.edu.cn/showproblem.php?pid=1298 题意:模拟手机9键,给出每个单词的使用频率.现在给出按键的顺序,问每次按键后首字是什么(也就是要概率最大的 ...
- POJ 1451 - T9 - [字典树]
题目链接:http://bailian.openjudge.cn/practice/1451/ 总时间限制: 1000ms 内存限制: 65536kB 描述 Background A while ag ...
- hdu 1979 DFS + 字典树剪枝
http://acm.hdu.edu.cn/showproblem.php?pid=1979 Fill the blanks Time Limit: 3000/1000 MS (Java/Others ...
- hdu 2846(字典树)
Repository Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total ...
- HDU 2846 Repository (字典树 后缀建树)
Repository Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total ...
- HDU 1671 (字典树统计是否有前缀)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1671 Problem Description Given a list of phone number ...
随机推荐
- Pycharm激活方法(license server方法)
pycharm所有版本 http://www.jetbrains.com/pycharm/download/previous.html 打开激活窗口 选择 Activate new license w ...
- 12.持久性后门----Ettercap之ARP中毒----RAR/ZIP & linux密码破解----kali上检测rootkits
持久性后门 生成PHP shell weevely generate 密码 /root/Desktop/404.php 靶机IP/404.php weevely http://192.168.1.10 ...
- mysql中的范式
范式 范式:Normal Format,是一种离散数学中的知识,是为了解决数据的存储与优化的问题:保存数据的存储之后,凡是能够通过关系寻找出来的数据,坚决不再重复存储,终极目标是为了减少数据的冗余.范 ...
- CentOS7创建本地源过程
1)使用yum安装http服务(主节点) yum -y install httpd 2)将httpd服务加入系统自启动服务并设置开机启动 systemctl start httpd #启动apache ...
- Node+Express+MySql实现简单增删改查和登录
var express = require('express'); var mysql = require('mysql'); var app = express(); var bodyParser ...
- thinkphp5发送邮件(实例代码 非常适合新手)
第一步:在(https://pan.baidu.com/s/1Fq6lONHlft5D6jvOnNwtoA)下载 phpmailer.rar 解压 然后把文件放入 vendor目录下 第二步:在 ap ...
- ThinkPHP中的"路由"是什么意思?
路由(route)是指根据url, 分配到对应的处理程序的映射. 简单来说,就是一个路径的解析,根据客户端提交的路径,将请求解析到相应的模块/控制器/方法上. 转载自:https://blog.csd ...
- python email模块
python email模块 官方文档 email模块 电子邮件包是一个用于管理电子邮件消息的库.它的特殊设计不用于向SMTP (RFC 2821).NNTP或其他服务器发送任何电子邮件消息;这些是模 ...
- Java web项目 本地配置https调试
一.创建密匙 网上有很多教程,就不在此赘述了. 假设最后生成的密匙为tomcat.keystore 密码为123456. 二.配置tomcat 首先,将密匙移到tomcat下根目录下. 进入conf文 ...
- Python字符串(str)方法调用
# str# n = 'pianYU'# v = n.capitalize() # 将字符串的首字母大写# print(v)## n = 'pianYI'# v1 = n.isupper() # 判断 ...