标签:des style http color os java io strong for
点击打开链接题目链接
6 xiasha westlake xiasha station 60 xiasha ShoppingCenterofHangZhou 30 station westlake 20 ShoppingCenterofHangZhou supermarket 10 xiasha supermarket 50 supermarket westlake 10 -1
50 Hint: The best route is: xiasha->ShoppingCenterofHangZhou->supermarket->westlake 虽然偶尔会迷路,但是因为有了你的帮助 **和**从此还是过上了幸福的生活。 ――全剧终――
#include<cstdio>
#include<cstring>
#define MAXN 0x3f3f3f3f
struct Node
{
int next[52];
int ids;
}trie[10010];
int dis[155][155];
int ans[155],vis[155];
int head;
int xx;
int tree_add(char *str)
{
int i,j,l,id;
l=strlen(str);
int s=0;
for(i=0;i<l;i++)
{
if(str[i]<'z'&&str[i]>'a')
id=str[i]-'a';
else
id=str[i]-'A'+26;
if(trie[s].next[id]==-1)
{
trie[s].next[id]=++head;
}
s=trie[s].next[id];
}
if(trie[s].ids==0)
{
trie[s].ids=++xx;
}
return trie[s].ids;
}
void dijkstra(int s,int t)
{
int i,j;
memset(vis,0,sizeof(vis));
for(i=1;i<=xx;i++)
{
ans[i]=dis[s][i];
}
for(i=1;i<=xx;i++)
{
int x;
int m=MAXN;
for(j=1;j<=xx;j++)
{
if(vis[j]==0&&ans[j]<m)
{
x=j;
m=ans[j];
}
}
vis[x]=1;
for(j=1;j<=xx;j++)
{
if(vis[j]==0&&ans[j]>ans[x]+dis[j][x])
{
ans[j]=ans[x]+dis[j][x];
}
}
}
if(ans[t]>10000000)
printf("-1\n");
else
printf("%d\n",ans[t]);
}
int main()
{
int n;
int i,j;
int a,b,c;
char str1[35],str2[35],str3[35],str4[35];
while(scanf("%d",&n)!=EOF&&n!=-1)
{
for(i=1;i<155;i++)
{
for(j=1;j<155;j++)
{
if(i!=j)
dis[i][j]=MAXN;
else
dis[i][j]=0;
}
}
for(i=0;i<10010;i++)
{
for(j=0;j<52;j++)
{
trie[i].next[j]=-1;
}
trie[i].ids=0;
}
head=0;
xx=0;
scanf("%s %s",str1,str2);
while(n--)
{
scanf("%s %s %d",str3,str4,&c);
a=tree_add(str3);
b=tree_add(str4);
if(dis[a][b]>c)
{
dis[a][b]=dis[b][a]=c;
}
}
int s=tree_add(str1);
int t=tree_add(str2);
dijkstra(s,t);
}
return 0;
}
HDU 2112 HDU Today 字典树+最短路dijkstra算法
标签:des style http color os java io strong for
原文地址:http://blog.csdn.net/qq_16843991/article/details/38867125