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 ...
随机推荐
- Our growth depends not on how many experiences we devour, but on how manywe digest.
rot. v/n. 腐烂 vibration.n. 震动 charcoal. n 木炭 wrinkle. v. 长皱纹 geometry. n. 几何学 walnut.n. 核桃 tailor. n. ...
- 应用安全 - 中间件漏洞 - Nostromo
CVE-2011-0751 Date: 2011.3 类型: 路径遍历 PoC:https://nvd.nist.gov/vuln/detail/CVE-2011-0751 CVE-2019-162 ...
- 红帽学习笔记[RHCSA] 第九课[文件归档、硬盘、分区以及自动挂载、Swap、链接]
文件归档 tar是什么 通过tar命令可以将大型文件汇集成一个文件(归档),注意没有压缩功能. 压缩方式 gzip 通过gzip过滤文档,使用最广泛 bzip2 通常比gzip压缩小,但是不如gzip ...
- 学习总结&实验报告1
Java实验报告 1.打印输出所有的“水仙花数”,所谓“水仙花数”是指一个3位数,其中各位数字立方和等于该数本身.例如,153是一个“水仙花数”. 实验代码: public class Project ...
- Unix时间戳和Java 的 System.currentTimeMillis()的区别
- (Windows)Python第三方库手动安装教程(以lxml库为例)
案例前提:已安装Python 已安装pip 1.进入官网https://www.lfd.uci.edu/~gohlke/pythonlibs/,搜索lxml库,下载到本地(放到Python目录下的Sc ...
- Codeforces - 1096G - Lucky Tickets - NTT
https://codeforc.es/contest/1096/problem/G 把数组分成前后两半,那么前半部分的各个值的表示方案的平方的和就是答案. 这些数组好像可以dp出来. 一开始设dp[ ...
- http协议中常见的状态码以及请求方式,http协议的组成
请求状态码: 2xxx:表示请求成功,例如200. 3xxx:表示请求被重定向,表示完成请求,需要进一步操作,例如 302. 4xxx:表示请求错误,例如:404,资源没有找到. 5xxx:表示服务器 ...
- Spring Boot实现SAAS平台的基本思路
一.SAAS是什么 SaaS是Software-as-a-service(软件即服务)它是一种通过Internet提供软件的模式,厂商将应用软件统一部署在自己的服务器 上,客户可以根据自己实际需求,通 ...
- iOS之Run Loop详解
转自标哥的技术博客(www.henishuo.com) 前言 做了一年多的IOS开发,对IOS和Objective-C深层次的了解还十分有限,大多还停留在会用API的级别,这是件挺可悲的事情.想学好一 ...