POJ 2503 Babelfish(map,字典树,快排+二分,hash)
题意:先构造一个词典,然后输入外文单词,输出相应的英语单词。
这道题有4种方法可以做:
1.map
2.字典树
3.快排+二分
4.hash表
参考博客:POJ2503两种解法:快速排序+二分查找与哈希表
思路1:可以使用map来做
代码:
#include<iostream>
#include<stdio.h>
#include<string>
#include<map>
using namespace std; map<string,bool>appear;//记录单词的存在
map<string,string>translate;//记录单词的翻译
int main(){
char s[40];
char english[20];
char foreign[20];
while(gets(s) && s[0]){
sscanf(s,"%s%s",english,foreign);
appear[foreign]=true;
translate[foreign]=english;
}
while(scanf("%s",s)!=EOF){//vc6.0中需要按两下ctrl+z才能结束循环
if(appear[s]) cout<<translate[s]<<endl;//string 不能用printf输出
else printf("eh\n");
}
return 0;
}
vc6.0中需要按两下ctrl+z才能结束循环?详见:EOF的使用
思路2:用字典树来做
代码:
#include<iostream>
#include<cstring>
#include<stdio.h>
using namespace std; const int MAX=26;
struct Trie {
Trie *next[MAX];
int v; //根据需要变化,1代表无此单词,-1代表有此单词
char english[20];
};
Trie *root=new Trie; char s[40];
char english[20];
char foreign[20];
char out[20];//存储要输出的内容 void createTrie(char *str){
int len = strlen(str);
Trie *p = root, *q;
for(int i=0; i<len; ++i){
int id = str[i]-'a';
if(p->next[id] == NULL){
// q = (Trie *)malloc(sizeof(Trie));
q = new Trie;
q->v = 1; //初始v==1
for(int j=0; j<MAX; ++j)
q->next[j] = NULL;
p->next[id] = q;
}
p = p->next[id];
}
p->v = -1; //若为结尾,则将v改成-1表示
strcpy(p->english,english);
}
int findTrie(char *str){
int len = strlen(str);
Trie *p = root;
for(int i=0; i<len; ++i){
int id = str[i]-'a';
p = p->next[id];
if(p == NULL) //若为空集,表示不存以此为前缀的串
return 0;
}
if(p->v == -1){
strcpy(out,p->english);
return 1; //存在单词
}
return 0;
} int main(){
int i;
for(i=0;i<MAX;i++)
root->next[i]=NULL; while(gets(s) && s[0]){
sscanf(s,"%s%s",english,foreign);
createTrie(foreign);
}
while(scanf("%s",s)!=EOF){//vc6.0中需要按两下ctrl+z才能结束循环 if(findTrie(s)==1) printf("%s\n",out);
else printf("eh\n");
}
return 0;
}
思路3:快排+二分
代码:
思路4:hash表
代码:
POJ 2503 Babelfish(map,字典树,快排+二分,hash)的更多相关文章
- poj 2503:Babelfish(字典树,经典题,字典翻译)
		Babelfish Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 30816 Accepted: 13283 Descr ... 
- poj 2503 Babelfish(字典树哈希)
		Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 29059 Accepted: 12565 Description You hav ... 
- poj 2503 Babelfish(Map、Hash、字典树)
		题目链接:http://poj.org/bbs?problem_id=2503 思路分析: 题目数据数据量为10^5, 为查找问题,使用Hash或Map等查找树可以解决,也可以使用字典树查找. 代码( ... 
- Poj 2503 Babelfish(Map操作)
		一.Description You have just moved from Waterloo to a big city. The people here speak an incomprehens ... 
- poj 2503 Babelfish(字典树或map或哈希或排序二分)
		输入若干组对应关系,然后输入应该单词,输出对应的单词,如果没有对应的输出eh 此题的做法非常多,很多人用了字典树,还有有用hash的,也有用了排序加二分的(感觉这种方法时间效率最差了),这里我参考了M ... 
- POJ 2001 Shortest Prefixes(字典树)
		题目地址:POJ 2001 考察的字典树,利用的是建树时将每个点仅仅要走过就累加.最后从根节点開始遍历,当遍历到仅仅有1次走过的时候,就说明这个地方是最短的独立前缀.然后记录下长度,输出就可以. 代码 ... 
- poj 2503 哈希 Map 字典树
		Babelfish Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 36967 Accepted: 15749 Descr ... 
- poj 2503 Babelfish(字典树或着STL)
		Babelfish Time Limit: 3000MS Memory Limit: 65536K Total Submissions: 35828 Accepted: 15320 Descr ... 
- POJ 1002 487-3279(字典树/map映射)
		487-3279 Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 309257 Accepted: 5 ... 
随机推荐
- sql 从另外一张表查询数据存入本表. (有关联的)
			UPDATE friends INNER JOIN users ON friends.friendid=users.userid SET friends.friendname=users.userna ... 
- Vue 引入ElementUI 2.0.11:依赖未发现的问题
			转自:https://blog.csdn.net/cslucifer/article/details/79019649 
- metaq入门部署到实战
			初识metaq zookeeper部署,这里单机zk为例. wget http://mirror.bit.edu.cn/apache/zookeeper/zookeeper-3.4.5/zookeep ... 
- C语言八进制和十六进制数
			一 赋值 int dex = 100;// 默认十进制 int oct = 0144;// 八进制,以0開始 int hex = 0x64;// 十六进制,以0x開始 二 输出 void show(i ... 
- 利用window.navigator.userAgent判断当前是否微信内置浏览器
			<!DOCTYPE HTML> <html lang="en"> <head> <meta charset="utf-8&quo ... 
- SharePoint 2013 对话框
			The quick way to open a sharepoint 2013 dialog modal form is via Javascript below 1 2 3 4 5 function ... 
- iOS中 扫描二维码/生成二维码具体解释 韩俊强的博客
			近期大家总是问我有没有关于二维码的demo,为了满足大家的需求,特此研究了一番,希望能帮到大家! 每日更新关注:http://weibo.com/hanjunqiang 新浪微博 指示根视图: se ... 
- Java 嵌套类和内部类演示样例<二>
			嵌套类(nested class)是一个在还有一个类或接口内部声明的类. 嵌套类分为两种:静态内部类(static inner class)和非静态嵌套类(non-static nested clas ... 
- 在Editplus中配置java的(带包)编译(javac)和执行(java)的方法
			配置的前提是电脑安装了JDK而且配置好了相关的环境变量(JAVA_HOME,path和classpath). 配置好后在命令行中输入javac和java验证是否配置成功: 假设出现上面的情况则说明配置 ... 
- modelsim-altera
			一. 1. Go to the menu Tools > Options. 2. In the “General” category, select “EDA Tool Options”. ... 
