题目描述

在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件:

1 .路径上的所有点的出边所指向的点都直接或间接与终点连通。

2 .在满足条件1 的情况下使路径最短。

注意:图G 中可能存在重边和自环,题目保证终点没有出边。

请你输出符合条件的路径的长度。

输入输出格式

输入格式:

输入文件名为road .in。

第一行有两个用一个空格隔开的整数n 和m ,表示图有n 个点和m 条边。

接下来的m 行每行2 个整数x 、y ,之间用一个空格隔开,表示有一条边从点x 指向点y 。

最后一行有两个用一个空格隔开的整数s 、t ,表示起点为s ,终点为t 。

输出格式:

输出文件名为road .out 。

输出只有一行,包含一个整数,表示满足题目᧿述的最短路径的长度。如果这样的路径不存在,输出- 1 。

输入输出样例

输入样例#1:

3 2
1 2
2 1
1 3
输出样例#1:

-1
输入样例#2:

6 6
1 2
1 3
2 6
2 5
4 5
3 4
1 5
输出样例#2:

3

说明

解释1:

如上图所示,箭头表示有向道路,圆点表示城市。起点1 与终点3 不连通,所以满足题

目᧿述的路径不存在,故输出- 1 。

解释2:

如上图所示,满足条件的路径为1 - >3- >4- >5。注意点2 不能在答案路径中,因为点2连了一条边到点6 ,而点6 不与终点5 连通。

对于30%的数据,0<n≤10,0<m≤20;

对于60%的数据,0<n≤100,0<m≤2000;

对于100%的数据,0<n≤10,000,0<m≤200,000,0<x,y,s,t≤n,x≠t。

代码

 #include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
#include<queue>
#define MAXN 500005
#define INF 0x3f3f3f3f
using namespace std; int vis[MAXN],to_des[MAXN],dis[MAXN];
int N,M;
int s,t; struct cc{int d,num;};
struct cmp{bool operator()(cc a,cc b){return a.d>b.d;}};
cc make_(int d,int num){cc a;a.d=d;a.num=num;return a;} vector<int> rG[MAXN],G[MAXN]; void Dijkstra(){
priority_queue<cc,vector<cc>,cmp> q;
memset(dis,0x3f,sizeof(dis));
memset(vis,,sizeof(vis)); q.push(make_(,s));
dis[s]=; while(!q.empty()){
cc x=q.top();q.pop();
vis[x.num]=; int flag=;
for(int i=;i<G[x.num].size();i++){
int to=G[x.num][i];
if(!to_des[to]) {flag=;break;}
}
if(flag) continue; for(int i=;i<G[x.num].size();i++){
int to=G[x.num][i];
if(dis[x.num]+<dis[to]){
dis[to]=dis[x.num]+;
q.push(make_(dis[to],to));
}
}
}
} void rdfs(int x){
vis[x]=to_des[x]=;
for(int i=;i<rG[x].size();i++){
int to=rG[x][i];
if(!vis[to]) rdfs(to);
}
} void init_(){
scanf("%d%d",&N,&M);
for(int i=;i<=M;i++){
int from,to;
scanf("%d%d",&from,&to);
G[from].push_back(to);
rG[to].push_back(from);
}
scanf("%d%d",&s,&t);
rdfs(t);
} int main(){
freopen("road.in","r",stdin);
freopen("road.out","w",stdout); init_();
Dijkstra(); if(dis[t]==INF) puts("-1");
else printf("%d\n",dis[t]); return ;
}

90分 TLE

转载:

首先把路线全倒过来,从终点往起点走一遍,把不行的点标起来,然后再从起点往终点做一个bfs,求最短的路线,就行了

 #include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<iostream>
#include<vector>
using namespace std;
int x,y,s,t,n,m,h[],f[],tr;
vector<int>a[],b[];
void dfs(int u){
if (h[u])return;
f[u]=;h[u]=;
for (int i=;i<b[u].size();i++)
dfs(b[u][i]);
}
void bfs(int u){
int g[],ans[],l=,fl[],xx;
memset(fl,,sizeof(fl));memset(ans,,sizeof(ans));
for (int i=;i<a[u].size();i++)
if (!fl[a[u][i]] && f[a[u][i]])
{ans[l]=;g[l++]=a[u][i];fl[a[u][i]]=;}
for (int i=;i<l;i++)
{
if (g[i]==t){tr=;printf("%d",ans[i]);break;}
xx=g[i];
for (int j=;j<a[xx].size();j++)
if (!fl[a[xx][j]] && f[a[xx][j]])
{ans[l]=ans[i]+;g[l++]=a[xx][j];fl[a[xx][j]]=;}
}
}
int main()
{
scanf("%d%d",&n,&m);
for (int i=;i<m;i++)
{
scanf("%d%d",&x,&y);
a[x].push_back(y);b[y].push_back(x);
}
scanf("%d%d",&s,&t);
dfs(t);
memset(h,,sizeof(h));
for (int i=;i<=n;i++)
{
if (!f[i])continue;
for (int j=;j<a[i].size();j++)
if (!f[a[i][j]]){h[i]=;break;}
}
for (int i=;i<=n;i++)
if (h[i])f[i]=;
if (f[s])bfs(s);
if (!tr)printf("-1");
return ;
}

std

NOIp 2014 #3 寻找道路 Label:图论的更多相关文章

  1. [NOIP2014]寻找道路(图论)

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

  2. NOIp 2014 #5 解方程 Label:数论?

    题目描述 已知多项式方程: a0+a1x+a2x^2+..+anx^n=0 求这个方程在[1, m ] 内的整数解(n 和m 均为正整数) 输入输出格式 输入格式: 输入文件名为equation .i ...

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

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

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

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

  5. noip寻找道路

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

  6. NOIP2014 寻找道路

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

  7. NOIP 2014 提高组 题解

    NOIP 2014 提高组 题解 No 1. 生活大爆炸版石头剪刀布 http://www.luogu.org/problem/show?pid=1328 这是道大水题,我都在想怎么会有人错了,没算法 ...

  8. NOIP 2014

    Prob.1 生活大爆炸版 石头剪刀布 模拟.代码: #include<cstdio> #include<cstring> #include<iostream> u ...

  9. Luogu 1351 NOIP 2014 联合权值(贪心,计数原理)

    Luogu 1351 NOIP 2014 联合权值(贪心,计数原理) Description 无向连通图 G 有 n 个点,n-1 条边.点从 1 到 n 依次编号,编号为 i 的点的权值为 Wi, ...

随机推荐

  1. App 开发:Hybrid 架构下的 HTML5 应用加速方案

    在移动 App 开发领域,主流的开发模式可分为 Native.Hybrid.WebApp 三种方式.然而 2013 年,纯 WebApp 开发模式的发展受到一定挫折,以 Facebook 为代表的独立 ...

  2. Ubuntu16.04 + Win 10 双系统 时间同步,启动项顺序,NumLock指示灯常亮

    1. Ubuntu & win10 双系统时间同步: 先在ubuntu下更新一下时间,确保时间无误: sudo apt-get install ntpdate sudo ntpdate tim ...

  3. hdu 1754:I Hate It(线段树,入门题,RMQ问题)

    I Hate It Time Limit: 9000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total S ...

  4. C# Func<T,TResult>

    using System; namespace FuncDemo { internal class Program { private static void Main() { //类似委托功能 Fu ...

  5. 【使用Unity开发Windows Phone上的2D游戏】(1)千里之行始于足下

    写在前面的 其实这个名字起得不太欠当,Unity本身是很强大的工具,可以部署到很多个平台,而不仅仅是可以开发Windows Phone上的游戏. 只不过本人是Windows Phone 应用开发出身, ...

  6. 第七篇:创建一个SOUI的Hello World

    从0开始一个SOUI项目 1.环境配置 SOUI项目本质是一个基于Win32窗口的应用程序.因此首先我们可以从Win32窗口应用程序向导创建一个简单的Win32项目. 并在第3页选择“Window应用 ...

  7. [荐]SWFObject 2最新版语法调用示例

    我一直都在用SWFObject 插入flash,好处多多,代码简洁,不会出现微软的“单击此处以激活控件”的提示(据可靠消息,这个是微软惹的官司,其结果是害苦了用户).不过先前的 调用方法着实有些繁琐, ...

  8. android AsyncTask介绍(转)

    android AsyncTask介绍 AsyncTask和Handler对比 1 ) AsyncTask实现的原理,和适用的优缺点 AsyncTask,是android提供的轻量级的异步类,可以直接 ...

  9. HDU 5900 QSC and Master 区间DP

    QSC and Master Problem Description   Every school has some legends, Northeastern University is the s ...

  10. 从DataReader中手动串行化JSON

    void WriteDataReader(StringBuilder sb, IDataReader reader) { ) { sb.Append("null"); return ...