/*
乍一看就是个最短路 SFPA
但是要保证路径上的所有点的出边所指向的点都直接或间接与终点连通。
这一点就蛋疼了0.0
开始想的是正着跑一边 每一个点的所有边都能符合条件 那这个点就符合条件0.0 可惜WA +RE 了
后来xyd大神说 可以先到这从终点跑一边 能到的标记 然后在枚举每个点的所有边指向的点 全被标记那么这个点就ok
最后SPFA
注意 正反建边 数组要大!!!!!!!!
还有 从终点跑一边 能到的标记时Dfs会TLE 所以0.0 BFs了
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#define maxn 10010
#define maxx 400010
using namespace std;
queue<int>q;
int n,m,head1[maxx],head2[maxx],num,s,t,f[maxn],ans[maxn],cn1[maxn],cn2[maxn];
struct node
{
int v,dis,pre;
}e1[maxx],e2[maxx];
/*int Dfs(int p)
{
f[p]=1;
for(int i=head2[p];i;i=e2[i].pre)
{
cn1[e2[i].v]=1;
if(f[e2[i].v]==0)
Dfs(e2[i].v);
}
}*/
void Bfs(int p)
{
q.push(p);
f[p]=;
int i;
while(!q.empty())
{
int k=q.front();
q.pop();
for(i=head2[k];i;i=e2[i].pre)
{
cn1[e2[i].v]=;
if(f[e2[i].v]==)
{
q.push(e2[i].v);
f[e2[i].v]=;
}
}
}
}
void Biu()
{
int i,j;
for(i=;i<=n;i++)
{
int g=;
for(j=head1[i];j;j=e1[j].pre)
if(cn1[e1[j].v]==)
g=;
if(g==)
cn2[i]=;
}
}
int main()
{
scanf("%d%d",&n,&m);
int i,x,y;
memset(ans,,sizeof(ans));
for(i=;i<=m;i++)
{
scanf("%d%d",&x,&y);
num++;
e1[num].v=y;
e1[num].dis=;
e1[num].pre=head1[x];
head1[x]=num;
num++;
e2[num].v=x;
e2[num].dis=;
e2[num].pre=head2[y];
head2[y]=num;
}
scanf("%d%d",&s,&t);
Bfs(t);
cn1[t]=;
Biu();
memset(f,,sizeof(f));
q.push(s);
ans[s]=;
f[s]=;
while(!q.empty())
{
int k=q.front();
q.pop();
f[k]=;
for(i=head1[k];i;i=e1[i].pre)
if(ans[e1[i].v]>ans[k]+e1[i].dis&&cn2[k]==)
{
ans[e1[i].v]=ans[k]+e1[i].dis;
if(f[e1[i].v]==)
{
q.push(e1[i].v);
f[e1[i].v]=;
}
}
}
if(ans[t]<0x7fffffff)printf("%d",ans[t]);
else printf("-1");
return ;
}

niop 2014寻找道路的更多相关文章

  1. [Luogu P2296][NOIP 2014]寻找道路

    emmm交了第8次才过. 这道题目测一道单源最短路问题,因此dijkstra或者spfa板子先准备好.因为题中对最短路有限定: 路径上的所有点的出边所指向的点都直接或间接与终点连通. 在满足条件1的情 ...

  2. NOIp 2014 寻找道路【图的遍历/最短路】By cellur925

    题目传送门 比较裸的图论,结果自己还是没做出来,我真菜. 我们根据题意,只要把不能通向终点的点求出,然后再分别以这些点为起点,求出它们能到达的点,这些点也不能在路径上. 之后跑一个最短路即可. 注意以 ...

  3. [NOIP 2014] 寻找道路

    [题目链接] http://uoj.ac/problem/19 [算法] 首先,在反向图上从终点广搜,求出每个点是否可以在答案路径中 然后在正向图中求出源点至终点的最短路,同样可以使用广搜 时间复杂度 ...

  4. Codevs 3731 寻找道路 2014年 NOIP全国联赛提高组

    3731 寻找道路 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找 ...

  5. NOIP2014 寻找道路

    2.寻找道路 (road.cpp/c/pas) [问题描述] 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1.路径上的所有点的出边所指 ...

  6. 洛谷P2296 寻找道路 [拓扑排序,最短路]

    题目传送门 寻找道路 题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点 ...

  7. 【DFS】【图论】NOIP2014寻找道路

    [NOIP2014]寻找道路 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1.路径上的所有点的出边所 ...

  8. 【洛谷P2296】[NOIP2014]寻找道路

    寻找道路 题目链接 这道题非常的水,按照题意, 先反向建边,从终点搜索,标记出可以到达终点的点 然后枚举一遍,判断出符合条件1的点 再从起点搜索一遍就可以了 #include<iostream& ...

  9. 洛谷P2296 寻找道路==codevs3731 寻找道路

    P2296 寻找道路 题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点 ...

随机推荐

  1. wndows常用命令

    1. 远程桌面 mstsc (Microsoft terminal services client)

  2. 转:SQL Case when 的使用方法

      Case具有两种格式.简单Case函数和Case搜索函数. --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ELSE '其他' EN ...

  3. iOS - 正则表达式判断邮箱、身份证..是否正确:

    iOS - 正则表达式判断邮箱.身份证..是否正确: //邮箱 + (BOOL) validateEmail:(NSString *)email {     NSString *emailRegex ...

  4. Swift中KIF测试的特点-b

    我最近在忙着回归到过去测试代码的老路子,使用KIF和XCTest框架,这样会使得iOS中的测试变得简单.当我开始捣鼓KIF的时候,我用Swift写的应用出了点小问题,不过最终还是很机智的搞定了.在我写 ...

  5. linux中硬盘及网卡的表示方法

    Linux中的所有设备均表示为/dev下的一个文件,各种IDE设备分配一个由hd前缀组成的文件:而对于各种SCSI设备,则分配了一个由sd前缀组成的文件,例如: IDE0接口上的主盘成为/dev/hd ...

  6. 概率质量函数:怀孕周期的PMF

    __author__ = 'dell' import surveyimport Pmfimport matplotlib.pyplot as pyplot table = survey.Pregnan ...

  7. nosql db and javascript performance

    http://blog.csdn.net/yiqijinbu/article/details/9053467 http://blog.nosqlfan.com/tags/javascript http ...

  8. 又是干货,这个春节感觉吃饱了。各方面---RHCS集群理论

    什么是集群?    集群是一组(>2)相互独立的,通过高速网络互联的计算机组成的集合.群集一般可以分为科学集群,负载均衡集群,高可用性集群三大类.    科学集群是并行计算的基础.它对外就好象一 ...

  9. 模拟I2C从机

    模拟I2C主机的比较多,但是从机相对主机而言要难很多,这个供大家借鉴. 这个从机程序支持主机对它的随机写和随机读,连续读和连续写没做,有兴趣的可以完善下,呵呵. //Microcontrol CODE ...

  10. autotrace显示Statistics很多信息为0(转)

    一朋友使用autotrace查看数据库执行计划发现结果如下,Statistics中很多信息为0,这个肯定是不正常现象,什么都可以为0,consistent gets也不可能为0. SQL> se ...