必须要批评下自己了,首先就是这个题目的迟疑不定,去年做字典树的时候就碰到这个题目了,当时没什么好的想法,就暂时搁置了,其实想法应该有很多,只是居然没想到。

同样都是对单词进行建树,并插入可能值,但是拨号键盘上的字母是对应多个的,给定拨号序列,有多种可能情况 输出其中最可能的一种,肯定要想到搜索啊,而且拨号数目不超过100,每个按键最多只对应4个字母,复杂度并不高,所以用dfs是可行的,对于每次递归深度,dfs找到最大的可能值的情况并输出。

接下来就是要批评自己了,下午一点钟开始做这个题目,居然被一个小bug搞了一个多小时,都没过样例,就是我的dfs写挫了,而且我迟迟没找到原因。。。真的要反省自己的代码编写能力了。

#include <iostream>
#include <cstdio>
#include <cstring>
using namespace std;
int tot;
char s[];
char press[][];
char num[];
int ansd;
char anss[],finds[];
bool flag;
struct node
{
node* ch[];
int cur,deep;
} tree[];
node* newNode()
{
node* p;
p=&tree[tot++];
for (int i=;i<;i++)
{
p->ch[i]=NULL;
}
p->cur=;
p->deep=;
return p;
}
void insertn(node* root,char* s1,int fee)
{
node* p=root;
int i=,k;
//puts(s1);
while (s1[i])
{
k=s1[i]-'a';
if (p->ch[k]==NULL)
{
//cout<<s1[i]<<" "<<p->deep<<endl;
p->ch[k]=newNode();
}
p->ch[k]->deep=i++;
p->ch[k]->cur+=fee;
p=p->ch[k];
}
}
void init()
{
strcpy(press[],"abc");
strcpy(press[],"def");
strcpy(press[],"ghi");
strcpy(press[],"jkl");
strcpy(press[],"mno");
strcpy(press[],"pqrs");
strcpy(press[],"tuv");
strcpy(press[],"wxyz"); }
void dfs(node* rt,char* s1,int maxd,int d)
{
node* p=rt;
if (d==maxd)
{
if (p->cur>ansd){
flag=;
ansd=p->cur;
for (int i=;i<d;i++)
anss[i]=finds[i];
anss[d]='\0';
}
return;
}
int k=s1[d]-'';
for (int i=;press[k][i];i++)
{ int q=press[k][i]-'a';
if (p->ch[q]!=NULL)
{
finds[d]=press[k][i];
}
else
continue; dfs(p->ch[q],s1,maxd,d+);
}
}
void test(node* root)
{
node* p=root;
for (int i=;i<;i++)
{
char c=i+'a';
cout<<c<<" "<<i<<endl;
if (p->ch[i]!=NULL) puts("Yes");
else puts("NO");
if (p->ch[i]!=NULL){
// cout<<c<<" "<<p->deep<<endl;
// p=p->ch[i];
//test(p);
}
}
}
int main()
{
//freopen("d:\\hdu_1298.txt","w",stdout);
int t,w,p,m,a,kase=;
scanf("%d",&t);
init();
while (t--)
{
tot=;
node* root=newNode();
root->deep=-;
scanf("%d",&w);
for (int i=;i<w;i++)
{
scanf("%s %d",s,&p);
//puts(s);
//cout<<root->deep<<endl;
//node*r1=root;
//cout<<root->deep<<endl;
insertn(root,s,p);
//cout<<root->deep<<endl;
} //test(root);
scanf("%d",&m);
printf("Scenario #%d:\n",++kase);
for (int i=;i<m;i++)
{
scanf("%s",num);
//puts(num);
ansd=;
flag=false; int len=strlen(num);
for (int i=;i<len;i++)
{
ansd=;
if (flag||i==){
flag=false;
dfs(root,num,i,);
}
if (flag)
puts(anss);
else
puts("MANUALLY");
}
printf("\n");
}
printf("\n");
}
return ;
}

HDU 1298 T9 字典树+DFS的更多相关文章

  1. HDU 1298 T9 ( 字典树 )

    题意 : 给你 w 个单词以及他们的频率,现在给出模拟 9 键打字的一串数字,要你在其模拟打字的过程中给出不同长度的提示词,出现的提示词应当是之前频率最高的,当然提示词不需要完整的,也可以是 w 个单 ...

  2. hdu 1298 T9(特里+DFS)

    pid=1298" target="_blank" style="">题目连接:hdu 1298 T9 题目大意:模拟手机打字的猜想功能.依据概 ...

  3. hdu 1298 T9

    字典树+DFS. #include<cstdio> #include<cstring> #include<cmath> #include<string> ...

  4. HDU 1298 T9(字典树+dfs)

    http://acm.hdu.edu.cn/showproblem.php?pid=1298 题意:模拟手机9键,给出每个单词的使用频率.现在给出按键的顺序,问每次按键后首字是什么(也就是要概率最大的 ...

  5. hdu 1298 字典树 + DFS (模拟T9文本输入)

    题意:       给你一些按键顺序,让你输出每一步中概率最大的那个单词,这里的概率计算方 法好好看看别弄错了,一开始就是因为弄错了,各种wa,比如 abc 1 ,ab 1,那么 ab 的概率就是2 ...

  6. HDU 1298 T9【字典树增加||查询】

    任意门:http://acm.hdu.edu.cn/showproblem.php?pid=1298 T9 Time Limit: 2000/1000 MS (Java/Others)    Memo ...

  7. HDU 6191 2017ACM/ICPC广西邀请赛 J Query on A Tree 可持久化01字典树+dfs序

    题意 给一颗\(n\)个节点的带点权的树,以\(1\)为根节点,\(q\)次询问,每次询问给出2个数\(u\),\(x\),求\(u\)的子树中的点上的值与\(x\)异或的值最大为多少 分析 先dfs ...

  8. hdu多校第五场1002 (hdu6625) three arrays 字典树/dfs

    题意: 给你两个序列a,b,序列c的某位是由序列a,b的此位异或得来,让你重排序列ab,找出字典序最小的序列c. 题解: 如果能找到a,b序列中完全一样的值当然最好,要是找不到,那也尽量让低位不一样. ...

  9. HDU1298 字典树+dfs

    T9 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submissi ...

随机推荐

  1. 047、Java中使用if…else if…else判断

    01.代码如下: package TIANPAN; /** * 此处为文档注释 * * @author 田攀 微信382477247 */ public class TestDemo { public ...

  2. javascript 原型链污染

    原理①javascript中构造函数就相当于类,并且可以将其实例化 ②javascript的每一个函数都有一个prototype属性,用来指向该构造函数的原型同样的javascript的每一个实例对象 ...

  3. python三大神器===》装饰器

    1.认识装饰器 如果你经常看我的博客,你已经学会了python的前两大‘神器’(迭代器,生成器),那么什么是装饰器呢?就如字面意义装饰器是对某个事物(通常指函数)进行装饰,让其在不修改任何内部代码的情 ...

  4. Kafka--windows下简单使用kafka命令

    参考 https://www.cnblogs.com/cici20166/p/9426417.html 启动zookeeper 只需要保证有可用的zookeeper,可以使用kafka内置的,也可以自 ...

  5. [YOLO]《You Only Look Once: Unified, Real-Time Object Detection》笔记

    一.简单介绍 目标检测(Objection Detection)算是计算机视觉任务中比较常见的一个任务,该任务主要是对图像中特定的目标进行定位,通常是由一个矩形框来框出目标. 在深度学习CNN之前,传 ...

  6. 网卡绑定多个ip

    现在我的树莓派上的wlan0的IP是192.168.31.237,之前通过双绞线连接时候eth0的ip是192.168.31.50 . 我就想啊,能不能把wlan0的ip设置成50.......... ...

  7. Swift Json解析与model互转

    Json的解码与编码操作,这里使用swift自带的类JSONDecoder 和 JSONEncoder 1.基础处理 如果你的 JSON 数据结构和你使用的 Model 对象结构一致的话,那么解析过程 ...

  8. 在各浏览器和各分辨率下如何让div内的table垂直水平居中?

    本文主要针对需要全屏显示的系统页面内,因为系统经常会用到表格table布局,偶尔的table需要显示在div的正中间,所以鄙人特此总结下div内table的万千姿态. <!DOCTYPE htm ...

  9. spring源码 AutowireCapableBeanFactory接口

    对于想要拥有自动装配能力,并且想把这种能力暴露给外部引用的BeanFactory类需要实现此接口.正常情况下,不要使用此接口应该更倾向于使用BeanFactory或者ListableBeanFacto ...

  10. mysql 分组查询教程

    1.分组 分组就是将一个“数据集”划分成若干个“小区域”,然后针对若干个“小区域”进行数据处理. 2.分组的特点 1.)group by的含义:将查询结果按照1个或多个字段进行分组,字段值相同的为一组 ...