HDU 1298 T9 字典树+DFS
必须要批评下自己了,首先就是这个题目的迟疑不定,去年做字典树的时候就碰到这个题目了,当时没什么好的想法,就暂时搁置了,其实想法应该有很多,只是居然没想到。
同样都是对单词进行建树,并插入可能值,但是拨号键盘上的字母是对应多个的,给定拨号序列,有多种可能情况 输出其中最可能的一种,肯定要想到搜索啊,而且拨号数目不超过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的更多相关文章
- HDU 1298 T9 ( 字典树 )
题意 : 给你 w 个单词以及他们的频率,现在给出模拟 9 键打字的一串数字,要你在其模拟打字的过程中给出不同长度的提示词,出现的提示词应当是之前频率最高的,当然提示词不需要完整的,也可以是 w 个单 ...
- hdu 1298 T9(特里+DFS)
pid=1298" target="_blank" style="">题目连接:hdu 1298 T9 题目大意:模拟手机打字的猜想功能.依据概 ...
- hdu 1298 T9
字典树+DFS. #include<cstdio> #include<cstring> #include<cmath> #include<string> ...
- HDU 1298 T9(字典树+dfs)
http://acm.hdu.edu.cn/showproblem.php?pid=1298 题意:模拟手机9键,给出每个单词的使用频率.现在给出按键的顺序,问每次按键后首字是什么(也就是要概率最大的 ...
- hdu 1298 字典树 + DFS (模拟T9文本输入)
题意: 给你一些按键顺序,让你输出每一步中概率最大的那个单词,这里的概率计算方 法好好看看别弄错了,一开始就是因为弄错了,各种wa,比如 abc 1 ,ab 1,那么 ab 的概率就是2 ...
- HDU 1298 T9【字典树增加||查询】
任意门:http://acm.hdu.edu.cn/showproblem.php?pid=1298 T9 Time Limit: 2000/1000 MS (Java/Others) Memo ...
- HDU 6191 2017ACM/ICPC广西邀请赛 J Query on A Tree 可持久化01字典树+dfs序
题意 给一颗\(n\)个节点的带点权的树,以\(1\)为根节点,\(q\)次询问,每次询问给出2个数\(u\),\(x\),求\(u\)的子树中的点上的值与\(x\)异或的值最大为多少 分析 先dfs ...
- hdu多校第五场1002 (hdu6625) three arrays 字典树/dfs
题意: 给你两个序列a,b,序列c的某位是由序列a,b的此位异或得来,让你重排序列ab,找出字典序最小的序列c. 题解: 如果能找到a,b序列中完全一样的值当然最好,要是找不到,那也尽量让低位不一样. ...
- HDU1298 字典树+dfs
T9 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submissi ...
随机推荐
- Python连载61-tkinter三种布局
一.pack布局举例 #pack布局案例 import tkinter baseFrame = tkinter.Tk() #以下代码都是创建一个组件,然后布局 btn1 = tkinter.Butto ...
- C#获取屏幕分辨率率
C#获取屏幕的分辨率 在C#中获取当前屏幕的分辨率的方法 1:rectangle类. 命名空间为:system.Drawing. system.Drawing.Rectangle rec=Scre ...
- Angular2的双向数据绑定
什么是双向绑定 如图: 双向绑定.jpg 双向绑定机制维护了页面(View)与数据(Data)的一致性.如今,MVVM已经是前段流行框架必不可少的一部分. Angular2中的双向绑定 双向绑定, ...
- CAD转PDF再由pdf转jpg图片
免费的PDF转JPG图片 https://www.gaitubao.com/pdf-to-jpg/
- 二十五、JavaScript之查找字符串中的字符串indexOf和lastIndexOf的用法
一.代码如下 二.效果如下 <!DOCTYPE html> <html> <meta http-equiv="Content-Type" conten ...
- 155-PHP stripos函数
<?php $str='password'; //定义一个字符串 $position=strpos($str,'S'); //查找字母s第一次出现的位置 echo '字母S的位置是'.$posi ...
- 060-PHP函数定义和调用
<?php function add($x,$y){ //定义函数add return $x+$y; } echo add(15,6); //调用函数并输出结果 ?>
- (转)深入理解JVM—JVM内存模型
原文地址:http://www.cnblogs.com/dingyingsi/p/3760447.html 我们知道,计算机CPU和内存的交互是最频繁的,内存是我们的高速缓存区,用户磁盘和CPU的交互 ...
- 11 数据存储(Unity3D)
所有的游戏开发都离不开数据存储的操作,Unity3D也不例外PlayerPrefs:PlayerPrefs是Unity系统自带的的一种最简单的存储方式,数据是使用字典的方法来存储的 PlayerPre ...
- spring boot 开发环境搭建(Eclipse)
Spring Boot 集成教程 Spring Boot 介绍 Spring Boot 开发环境搭建(Eclipse) Spring Boot Hello World (restful接口)例子 sp ...