HDU2112 HDU Today 最短路+字符串哈希
HDU Today
Time Limit: 15000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 26104 Accepted Submission(s): 6341
这样住了一段时间,徐总对当地的交通还是不太了解。有时很郁闷,想去一个地方又不知道应该乘什么公交车,在什么地方转车,在什么地方下车(其实徐总自己有车,却一定要与民同乐,这就是徐总的性格)。
徐总经常会问蹩脚的英文问路:“Can you help me?”。看着他那迷茫而又无助的眼神,热心的你能帮帮他吗?
请帮助他用最短的时间到达目的地(假设每一路公交车都只在起点站和终点站停,而且随时都会开)。
第二行有徐总的所在地start,他的目的地end;
接着有n行,每行有站名s,站名e,以及从s到e的时间整数t(0<t<100)(每个地名是一个长度不超过30的字符串)。
note:一组数据中地名数不会超过150个。
如果N==-1,表示输入结束。
xiasha->ShoppingCenterofHangZhou->supermarket->westlake
虽然偶尔会迷路,但是因为有了你的帮助
**和**从此还是过上了幸福的生活。
――全剧终――
题解:最短路,加了哈希要快一点480ms
提示:注意初始化和无向边。。
#include<bits/stdc++.h>
#define N 170
#define mes(x) memset(x, 0, sizeof(x));
const long long mod = 1e9+;
const int INF = <<;
using namespace std;
map<int ,int >mp;
int plat[N][N];
int dis[N],dir[N];
int dj(int start,int end, int n){
int i, min, t, j;
//if(start == end) return 0;
if(!(start&&end)) return -;
for(i=;i<=n;i++) dis[i] = plat[start][i];
for(j=;j<=n;j++){
min = INF;t=;
for(i=;i<=n;i++){
if(min > dis[i] && !dir[i] ){
min = dis[i];
t = i;
}
}
dir[t] = ;
for(i=;i<=n;i++){
if(dis[i] > dis[t] + plat[t][i])
dis[i] = dis[t] + plat[t][i];
}
}
if(dis[end] < INF) return dis[end];
return -;
}
int Hash(char* s){
long long seed=;// 31 131 1313 13131 131313 etc..
long long hash=;
while(*s=='')s++;//处理
while(*s)
hash=hash*seed+(*s++);
return (hash & 0x7FFFFFFF);
}
int main()
{
char s1[],s2[];
int n, start, end, t, l, ans, ha1, ha2, i, j;
while(~scanf("%d", &n)&&n!=-){
for(i=;i<=;i++)
for(j=;j<=;j++)
{
if(i==j) plat[i][j] = ;
else
plat[i][j] = INF;
}
memset(dir, , sizeof(dir));
mp.clear();
scanf("%s%s", s1, s2);
start = Hash(s1); end = Hash(s2);
t = ;
while(n--){
scanf("%s%s%d", s1, s2, &l);
ha1 = Hash(s1);ha2 = Hash(s2);
if(!mp[ha1]) mp[ha1] = t++;
if(!mp[ha2]) mp[ha2] = t++;
if(plat[mp[ha1]][mp[ha2]] > l){
plat[mp[ha1]][mp[ha2]] = l;
plat[mp[ha2]][mp[ha1]]= l;
}//有毒啊,双向的
}
ans = dj(mp[start], mp[end], t-);
printf("%d\n", ans);
}
return ;
}
HDU2112 HDU Today 最短路+字符串哈希的更多相关文章
- HDU 1880 题解(字符串哈希)
题面: 魔咒词典 Time Limit: 8000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Total Subm ...
- HDU 2087 剪花布条 (字符串哈希)
http://acm.hdu.edu.cn/showproblem.php?pid=2087 Problem Description 一块花布条,里面有些图案,另有一块直接可用的小饰条,里面也有一些图 ...
- HDU 1880 魔咒词典(字符串哈希)
题目链接 Problem Description 哈利波特在魔法学校的必修课之一就是学习魔咒.据说魔法世界有100000种不同的魔咒,哈利很难全部记住,但是为了对抗强敌,他必须在危急时刻能够调用任何一 ...
- 【HDU5469】Antonidas(点分治,字符串哈希)
[HDU5469]Antonidas(点分治,字符串哈希) 题面 HDU Vjudge 题解 啊哈?什么垃圾一眼点分治+Hash判断,哈哈哈哈哈,让我来码码码. 诶,怎么WA了.改改改改改. 诶,怎么 ...
- 洛谷P3370 【模板】字符串哈希
P3370 [模板]字符串哈希 143通过 483提交 题目提供者HansBug 标签 难度普及- 提交 讨论 题解 最新讨论 看不出来,这题哪里是哈希了- 题目描述 如题,给定N个字符串(第i个 ...
- ACM: HDU 2544 最短路-Dijkstra算法
HDU 2544最短路 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descrip ...
- HDU2594 Simpsons’ Hidden Talents 字符串哈希
最近在学习字符串的知识,在字符串上我跟大一的时候是没什么区别的,所以恶补了很多基础的算法,今天补了一下字符串哈希,看的是大一新生的课件学的,以前觉得字符串哈希无非就是跟普通的哈希没什么区别,倒也没觉得 ...
- LA 6047 Perfect Matching 字符串哈希
一开始我用的Trie+计数,但是不是计多了就是计少了,后来暴力暴过去的…… 看了别人的代码知道是字符串哈希,但是仍有几个地方不理解: 1.26^500溢出问题 2.没考虑哈希碰撞? 跪求指点! #in ...
- AC日记——【模板】字符串哈希 洛谷 3370
题目描述 如题,给定N个字符串(第i个字符串长度为Mi,字符串内包含数字.大小写字母,大小写敏感),请求出N个字符串中共有多少个不同的字符串. 友情提醒:如果真的想好好练习哈希的话,请自觉,否则请右转 ...
随机推荐
- highcharts 实例
<script src="../../Scripts/jquery-1.7.2.min.js" type="text/javascript">< ...
- logstash学习2
从geoip字段取location的longitude字段 [geoip][location][0] 支持变量内插 "the longitude is %{[geoip][location] ...
- 【py网页】urlopen的补充,完美
urllib 是 python 自带的一个抓取网页信息一个接口,他最主要的方法是 urlopen(),是基于 python 的 open() 方法的.下面是主要说明: 1 urllib.urlopen ...
- Unexpected error: UnicodeDecodeError: 'ascii' codec can't decode byte 0xd2 in position 69: ordinal not in range(128)-解决办法
- linux与KVM虚拟里的windows实现文件共享
1.把windows系统里的共享文件设置为共享 2.在linux系统里 mount -t cifs //192.168.0.254/work /data/tmp -o username=test,pa ...
- [Android新手区] SQLite 操作详解--SQL语法
该文章完全摘自转自:北大青鸟[Android新手区] SQLite 操作详解--SQL语法 :http://home.bdqn.cn/thread-49363-1-1.html SQLite库可以解 ...
- Linux中重定向命令行
http://www.ahlinux.com/start/base/3170.html
- mongo 学习教程(全)
看的是爱酷学习网的视频:http://www.icoolxue.com/album/show/98 01 安装 1.先建mongoDB-data文件夹存数据 2.安装DB 3.设置环境变量:把bin目 ...
- 如何在ecshop商品详情页显示供货商信息
以下范例以ecshop2.7.2原型做为修改: 1.首先需要修改程序文件,将供货商读取出来,然后赋值给模板, 打开文件 /goos.php, 在 $smar ...
- 解析八大O2O典范:他们都做了什么?
随着无线技术的发展二维码的发展以及智能手机的普及,零售的解决方案不仅在在一台电脑上解决,可以从线上到线下,为消费者贯通线上线下的购物体验.人人都爱O2O,可做得好的O2O案例却并不多.要解决利益分配. ...