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

同样都是对单词进行建树,并插入可能值,但是拨号键盘上的字母是对应多个的,给定拨号序列,有多种可能情况 输出其中最可能的一种,肯定要想到搜索啊,而且拨号数目不超过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. 我的博客 Hexo 还是Jekyll

    我的博客 Hexo 还是Jekyll 标签(空格分隔): 博客 很喜欢找一些博客主题,目前发现几个比较不错的 Hexo: 阿里中间件 我的个人博客-Material主题 我的个人博客-Fluid主题 ...

  2. 西门子 S7-200CN CPU 224CN EEPROM芯片

    拆下来了个 224CN 的EEPROM芯片

  3. Linux服务器命令大全

    快捷提示键: table 查看文件夹:  ls , ls –all ,ls –l,ll 进入某个文件夹: cd usr/local 回到root 目录 : cd /root/ 回到根目录:cd / 回 ...

  4. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 字体图标(Glyphicons)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  5. maven集成SSM项目,Tomcat部署运行——SSM整合框架搭建(二)之问题

    问题一.当放开controller中的方法,出现如下问题 ### Error querying database. Cause: org.springframework.jdbc.CannotGetJ ...

  6. JS - 获取任意一天的0点和23:59:59时间

    转载自 https://www.cnblogs.com/sk-3/archive/2019/07/23/11232750.html 使用了setHours() 方法 setHours() 方法用于设置 ...

  7. Linux系统下的/etc/nsswitch.conf文件

    一.什么是nsswithch.conf(服务搜索顺序)文件呢? nsswitch.conf(name service switch configuration,名字服务切换配置)文件位于/etc目录下 ...

  8. python3调用微软js引擎ChakraCore

    有关ChakraCore介绍请移步:https://github.com/Microsoft/ChakraCore 使用案例GitHub源码:https://github.com/pyAppman/C ...

  9. 一百零八、SAP的OO-ALV之二,创建屏幕Screen

    一.在资源管理器,右键->创建屏幕 二.输入4位数字 三.输入屏幕的描述 四.在逻辑流里面PBO用于显示屏幕,PAI用于用户交互. 五.在元素清单里面,在屏幕中的所有元素都是在元素清单中的

  10. HDU_4912 Path on the tree 2014多校5 贪心+LCA

    当时刚学LCA-tarjan不久,就比赛有这个题,但没想到还是没做出来..一开始以为是DP来着,没想到是贪心,想想也对,从树的最下层开始,每次遇到询问的点,就找到他们的LCA(路径里面必经LCA),然 ...