两次bfs;

第一次bfs逆向搜索,得到每个点到终点的最短距离,找出最短路;第二次bfs根据最短距离可以选择满足条件的最短路。

注意!碰到这种很大数据量的题目一定要记得用scanf,printf 输入输出!!!

ps:uva和hdu中数据输入有些出入。。。(uva中没有输入T。。。)

 #include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std; const int maxn=+;
const int inf=; struct node {
int u,v,w;
int next;
void init (int nu,int nv,int nw,int nnext){
u=nu;v=nv;w=nw;next=nnext;
}
}edges[maxn*]; int n,m,cnt;
int head[maxn],d[maxn],visit[maxn]; void addedges (int u,int v,int w){
edges[cnt].init (u,v,w,head[u]);
head[u]=cnt++;
} void anti_bfs (){
queue<int> q;
while (!q.empty ())
q.pop ();
q.push (n);
d[n]=;
while (!q.empty ()){
int u=q.front ();
q.pop ();
for (int i=head[u];i!=-;i=edges[i].next){
int v=edges[i].v;
if (d[v]==-){
d[v]=d[u]+;
q.push (v);
}
}
}
printf ("%d\n",d[]);//cout<<"error";
} void bfs (){
int p[maxn*];
int l,r;
l=r=;
p[r++]=;
visit[]=;
while (l<r){
int mi=inf;
for (int j=l;j<r;j++){
int u=p[j];
for (int i=head[u];i!=-;i=edges[i].next){
int v=edges[i].v;
//if (visit[v]) continue ;
if (d[u]==d[v]+)
mi=min (mi,edges[i].w);//cout<<edges[i].w<<"err"<<mi<<endl;
}
}
printf ("%d",mi);
int num=r;
for (int j=l;j<r;j++){
int u=p[j];
for (int i=head[u];i!=-;i=edges[i].next){
int v=edges[i].v;
if (visit[v]) continue ;
if (d[u]!=d[v]+)
continue ;
if (mi==edges[i].w){
p[num++]=v;
visit[v]=;//cout<<"error";
if (v==n){
printf ("\n");
return ;
}
}
}
}
printf (" ");
l=r;
r=num;
}
} int main (){
int t;
scanf ("%d",&t);
while (t--){
cnt=;
memset (head,-,sizeof head);
memset (d,-,sizeof d);
memset (visit,,sizeof visit);
scanf ("%d%d",&n,&m);
for (int i=;i<m;i++){
int a,b,c;
scanf ("%d%d%d",&a,&b,&c);
addedges (a,b,c);
addedges (b,a,c);
}
anti_bfs ();
bfs ();
}
return ;
}

UVA 1599 Ideal Path (HDU 3760)的更多相关文章

  1. uva 1599 ideal path(好题)——yhx

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAABGYAAAODCAYAAAD+ZwdMAAAgAElEQVR4nOy9L8/0ypH/Pa8givGiyC

  2. UVA 1599 Ideal Path(bfs1+bfs2,双向bfs)

    给一个n个点m条边(<=n<=,<=m<=)的无向图,每条边上都涂有一种颜色.求从结点1到结点n的一条路径,使得经过的边数尽量少,在此前提下,经过边的颜色序列的字典序最小.一对 ...

  3. UVA 1599 Ideal Path

    题意: 给出n和m,n代表有n个城市.接下来m行,分别给出a,b,c.代表a与b之间有一条颜色为c的道路.求最少走几条道路才能从1走到n.输出要走的道路数和颜色.保证颜色的字典序最小. 分析: bfs ...

  4. Uva 1599 Ideal Path - 双向BFS

    题目连接和描述以后再补 这题思路很简单但还真没少折腾,前后修改提交了七八次才AC...(也说明自己有多菜了).. 注意问题: 1.看清楚原题的输入输出要求,刚了书上的中文题目直接开撸,以为输入输出都是 ...

  5. 【每日一题】 UVA - 1599 Ideal Path 字典序最短路

    题解:给一个1e5个点2e5条边,每个边有一个值,让你输出一条从1到n边的路径使得:条数最短的前提下字典序最小. 题解:bfs一次找最短路(因为权值都是1,不用dijkstra),再bfs一次存一下路 ...

  6. UVa 1599 Ideal Path (两次BFS)

    题意:给出n个点,m条边的无向图,每条边有一种颜色,求从结点1到结点n颜色字典序最小的最短路径. 析:首先这是一个最短路径问题,应该是BFS,因为要保证是路径最短,还要考虑字典序,感觉挺麻烦的,并不好 ...

  7. UVa 1599 Ideal Path【BFS】

    题意:给出n个点,m条边,每条边上涂有一个颜色,求从节点1到节点n的最短路径,如果最短路径有多条,要求经过的边上的颜色的字典序最小 紫书的思路:第一次从终点bfs,求出各个节点到终点的最短距离, 第二 ...

  8. UVA 1599 Ideal Path(双向bfs+字典序+非简单图的最短路+队列判重)

    https://vjudge.net/problem/UVA-1599 给一个n个点m条边(2<=n<=100000,1<=m<=200000)的无向图,每条边上都涂有一种颜色 ...

  9. 【例题 6-20 UVA - 1599】Ideal Path

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 逆向做一遍bfs. 得到终点到某个点的最短距离. 这样,我们从起点顺序的时候. 就能知道最短路的下一步是要走哪里了. 这样,我们从起 ...

随机推荐

  1. Android SqLite升级

    android开发中,如果大家使用到了sqlite就会牵涉到它的升级问题,因为升级后的表结构可能完全不一样,会有字段的添加或者删除等..    sqlite升级思路:      1:将表A重新命名:例 ...

  2. [原]用C#模拟实现扑克牌发牌、排序程序…

    (1)52张扑克牌,四种花色(红桃.黑桃.方块和梅花),随机发牌给四个人. (2)最后将四个人的扑克牌包括花色打印在控制台上. 其中:     花色和点数用枚举类型实现     每张扑克牌用结构实 ...

  3. 【转】Tomcat集群Cluster实现原理剖析

    此文章来源:http://zyycaesar.iteye.com/blog/296606 此文章作者:zyycaesar 对于WEB应用集群的技术实现而言,最大的难点就是如何能在集群中的多个节点之间保 ...

  4. 1006 Do the Untwist

    考察编程基础知识,用到字符和数字相互转化等.形式是描述清楚明文和暗文的转化规则. #include <stdio.h> #include <string.h> #define ...

  5. Unity3D自定义地形的笔刷,刷出别样地形

    ​ 是不是很简单呀,大家可以发挥想象刷出特殊的地形,小鸡呀,或者其他的logo之类(顶视图看上去效果很棒)的地形. 最后把我找的笔刷上传,Gizmos 注意: 如果文件夹及图片导入后,地形系统的笔刷无 ...

  6. Kth Smallest Element in a BST 解答

    Question Given a binary search tree, write a function kthSmallest to find the kth smallest element i ...

  7. openssl 生成CSR

    openssl 生成CSR 2013-12-27 15:05 3699人阅读 评论(1) 收藏 举报  分类: Security(38)  C/C++(105)  版权声明:本文为博主原创文章,未经博 ...

  8. 代码中实际运用memcached——java

    以下文章取自:http://jameswxx.iteye.com/blog/1168711 memcached的java客户端有好几种,http://code.google.com/p/memcach ...

  9. Web Service中的XFire 传输List 自定义对象.

    我把这个创建的步骤和代码的贴出来,. 首先新建一个工程,取名就随便点啦..MyWebService,然后复制jar包到lib目录下, 创建包,建立接口..写一个javaBean的类, 以下是一个简单的 ...

  10. Android漫游记(1)---内存映射镜像(memory maps)

    Android系统内核基于Linux2.6+内核,因此,其在进程内存管理方面的非常多机制和Linux是非常相像的.首先,让我们来看一个典型的Android进程的内存镜像(App进程和Native本地进 ...