题目大意:

对于一个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. 手动编译protobuf3的C++源码

    Windows下编译 官方文档 第三方文档 准备工具 Visual Studio 2013 CMake https://cmake.org/ Git https://git-scm.com/ 需要注意 ...

  2. Python爬虫通过替换http request header来欺骗浏览器实现登录

    以豆瓣为例,访问https://www.douban.com/contacts/list 来查看自己关注的人,要登录才能查看. 如果用requests.get()方法获取这个http,没登录只能抓取回 ...

  3. PHP函数和数组

    所有代码可以在https://www.github.com/lozybean/learn_www中查看 PHP函数 PHP中还是有很多函数式编程的影子,函数功能还是比较强大的. 1. 函数用funct ...

  4. ajax写登录页面

    静态配置 STATICFILES_DIRS = ( os.path.join(BASE_DIR,'my_blog','static'), ) AUTH_USER_MODEL = "app01 ...

  5. 【二分图】P3386洛谷模板

    题目背景 二分图 题目描述 给定一个二分图,结点个数分别为n,m,边数为e,求二分图最大匹配数 输入输出格式 输入格式: 第一行,n,m,e 第二至e+1行,每行两个正整数u,v,表示u,v有一条连边 ...

  6. 数据结构4——浅谈DancingLinks的思想及应用

    在学习DancingLinks之前,我们先来回顾一下我们以前学过的回溯法. 我们学习基础的回溯法的时候,我们都是先判断是否达到解,然后继续搜索. 对于搜到的下一个点,将他标记为使用过( vis[i]= ...

  7. screen使用

    远程连接Linux系统后,需要在后台运行一下程序,nohup呢感觉不大直观,打心里不信任它..那么screen就是很棒的工具,除了"后台"运行程序,还能做到分屏等等. 下面介绍一下 ...

  8. [认证授权] 6.Permission Based Access Control

    在前面5篇博客中介绍了OAuth2和OIDC(OpenId Connect),其作用是授权和认证.那么当我们得到OAuth2的Access Token或者OIDC的Id Token之后,我们的资源服务 ...

  9. 一次完整的http的请求过程

    一个完整的http的完成请求过程: 输入网址-> 域名解析-> tcp的三次握手-> 建立tcp连接后发起http 请求-> 服务器响应http ,发送数据给浏览器->  ...

  10. [转]python执行bash指令,如果指令返回错误,如何优雅的结束python程序

    如果是有返回值的可执行文件可以直接获取return code, 如果error code 直接退出. import os ret = os.system("COMMAND LINE" ...