题目大意:

对于一个n个房间m条路径的迷宫(Labyrinth)(2<=n<=100000, 1<=m<=200000),每条路径上都涂有颜色,颜色取值范围为1<=c<=10^9。求从节点1到节点n的一条路径,使得经过的边尽量少,在这样的前提下,如果有多条路径边数均为最小,则颜色的字典序最小的路径获胜。一条路径可能连接两个相同的房间,一对房间之间可能有多条路径。输入保证可以从节点1到达节点n。

这题思路很简单但还真没少折腾,前后修改提交了七八次才AC...(也说明自己有多菜了)..

注意问题:

1.看清楚原题的输入输出要求,刚了书上的中文题目直接开撸,以为输入输出都是只有一个情况的,所以一开始没加循环导致了WA

2. bfs要解决重复入队问题,在bfs1中由于一开始的方法导致重复入队,提交后TLE

3. 将d数组初始化为一个较大的整数 INF = 0x5ffffff ,然后找最小颜色的时候比INF小就修改,提交后WA,原因可能为测试数据中存在颜色号码真的为INF的数据,改为用-1充当INF

总结:

1.要看清楚原题的输入输出要求

2.bfs重复入队问题的解决方法

3.INF标识尽量用题目不可能出现的数据,如果数据都是正整数,可用-1

AC代码:

#include <iostream>
#include <cstring>
#include <vector>
#include <queue>
#include <stdio.h>
#include <algorithm>
#define maxn 100005
using namespace std;
struct ver
{
int next,color;
ver(int a,int b) : next(a),color(b) {}
ver() {}
}; vector<ver> G[maxn];
int vis[maxn];
int d[maxn];
int n,m;
int res[maxn];
int inque[maxn]; void bfs1()
{
memset(d,-1,sizeof(d));
int u,t;
queue<int> Q;
d[n] = 0;
Q.push(n);
while(!Q.empty())
{
t = Q.front(); Q.pop();
int sz = G[t].size();
for(int i =0; i < sz; ++i)
{
u = G[t][i].next;
if(u == 1)
{
d[1] = d[t] + 1;
return;
}
if(d[u] == -1) //未访问过
{
d[u] = d[t] + 1;
Q.push(u);
}
}
}
} void bfs2()
{ memset(res,0,sizeof(res));
memset(inque,0,sizeof(inque));
queue<int> Q;
int end,clr,minc;
int begin = 1;
Q.push(begin);
while(!Q.empty())
{
begin = Q.front(); Q.pop();
if(begin == n) return;
minc = -1;
for(int i = 0; i< G[begin].size(); i++) //1st find min color
{
end = G[begin][i].next;
clr = G[begin][i].color;
if(d[end] == d[begin]-1)
{
if(minc == -1) minc = clr;
else minc = min(minc,clr);
}
}
int index = d[1] - d[begin]; //当前步长
if(res[index] == 0) res[index] = minc;
else res[index] = min(res[index],minc); for(int j = 0; j < G[begin].size();j++) //2st go
{
end = G[begin][j].next;
clr = G[begin][j].color;
if(clr == minc && d[end] == d[begin]-1 && !inque[end])
{
Q.push(end);
inque[end] = 1;
}
} }
} int main()
{
int a,b,c;
while(scanf("%d %d",&n,&m) == 2)
{
for(int i = 0; i <= n; ++i) G[i].clear();
for(int i = 0; i < m; ++i)
{
scanf("%d %d %d",&a,&b,&c);
if(a == b) continue;
ver edge1(b,c);
ver edge2(a,c);
G[a].push_back(edge1);
G[b].push_back(edge2);
}
bfs1();
bfs2(); printf("%d\n",d[1]);
printf("%d",res[0]);
for(int i = 1; i < d[1]; ++i)
printf(" %d",res[i]);
printf("\n");
}
return 0;
}

  

Uva 1599 Ideal Path - 双向BFS的更多相关文章

  1. UVa 1599 Ideal Path【BFS】

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

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

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

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

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

  4. UVa 1599 Ideal Path (两次BFS)

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

  5. UVA 1599 Ideal Path (HDU 3760)

    两次bfs: 第一次bfs逆向搜索,得到每个点到终点的最短距离,找出最短路:第二次bfs根据最短距离可以选择满足条件的最短路. 注意!碰到这种很大数据量的题目一定要记得用scanf,printf 输入 ...

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

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

  7. UVA 1599 Ideal Path

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

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

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

  9. POJ——3126Prime Path(双向BFS+素数筛打表)

    Prime Path Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 16272   Accepted: 9195 Descr ...

随机推荐

  1. Git详解之四:服务器上的Git

    服务器上的 Git 到目前为止,你应该已经学会了使用 Git 来完成日常工作.然而,如果想与他人合作,还需要一个远程的 Git 仓库.尽管技术上可以从个人的仓库里推送和拉取修改内容,但我们不鼓励这样做 ...

  2. python实现散列表的直接寻址法

    散列表(Hash table,也叫哈希表),是根据键(Key)而直接访问在内存存储位置的数据结构.也就是说,它通过计算一个关于键值的函数, 将所需查询的数据映射到表中一个位置来访问记录,这加快了查找速 ...

  3. JS函数的参数声明中用 var 与不用 var的区别

    1.var 声明的变量,作用域是当前 function 2.没有声明的变量,直接赋值的话, 会自动创建变量,但作用域是全局的. 例如: function doSth() { a = "AAA ...

  4. vue2.0笔记《二》组件

    主要内容:如何注册组件.如何使用组件.父组件子组件之间值的传递 1.如何注册组件 第一步:通过import将子组件载入父组件的js中 // 第一步:通过import将子组件载入父组件的js中 impo ...

  5. 常见ie css hack

    .all IE{property:value\9;} .gte IE 8{property:value\0;} .lte IE 7{*property:value;} .IE 8/9{property ...

  6. findhex

    FindPattern(hD3D, 0x128000, (PBYTE)"\xC7\x06\x00\x00\x00\x00\x89\x86\x00\x00\x00\x00\x89\x86&qu ...

  7. 读汤姆大叔《JavaScript变量对象》笔记

    一段简单的JavaScript代码思考 先看一段简单的代码,打印结果是??为什么why?? 从上述打印结果不难看出,在打印基本变量num.函数表达式fn.函数声明fun时,就已经知道变量num.函数表 ...

  8. 5、ABPZero系列教程之拼多多卖家工具 修改User表结构

    毕竟这个框架是外国人开发的,对于我们国人来说还是有些地方并不合适,就好比如注册时需要填写名字.姓氏一样,今天要说的就是如何去掉这2个字段. 先看如下修改完成的效果图 User表结构修改 修改User类 ...

  9. 使用Xamarin实现跨平台移动应用开发(转载)

    刚在朋友圈看到张善友,转发的一条分享“使用Xamarin实现跨平台移动应用开发”,写的确实很详细得体,从收费到开源,这段时间xamarin受到不少质疑,如此文http://blog.csdn.net/ ...

  10. 2017-07-20聊聊《C#本质论》

    第一次接触<C#本质论>是在这个链接.那时候刚学写C#,而且它的语言风格深深吸引了我,噢对了还有它强大的IDE--VS.这个链接里的书确实不错.文中提到: 虽然这三本书都是外国原著的,但是 ...