NOIp 2014 #3 寻找道路 Label:图论
题目描述
在有向图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 。
输入输出样例
3 2
1 2
2 1
1 3
-1
6 6
1 2
1 3
2 6
2 5
4 5
3 4
1 5
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:图论的更多相关文章
- [NOIP2014]寻找道路(图论)
题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点连通. 2 .在满足条 ...
- NOIp 2014 #5 解方程 Label:数论?
题目描述 已知多项式方程: a0+a1x+a2x^2+..+anx^n=0 求这个方程在[1, m ] 内的整数解(n 和m 均为正整数) 输入输出格式 输入格式: 输入文件名为equation .i ...
- Codevs 3731 寻找道路 2014年 NOIP全国联赛提高组
3731 寻找道路 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找 ...
- 【DFS】【图论】NOIP2014寻找道路
[NOIP2014]寻找道路 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1.路径上的所有点的出边所 ...
- noip寻找道路
题目描述 在有向图G 中,每条边的长度均为1 ,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1 .路径上的所有点的出边所指向的点都直接或间接与终点连通. 2 .在满足条 ...
- NOIP2014 寻找道路
2.寻找道路 (road.cpp/c/pas) [问题描述] 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找一条从起点到终点的路径,该路径满足以下条件: 1.路径上的所有点的出边所指 ...
- NOIP 2014 提高组 题解
NOIP 2014 提高组 题解 No 1. 生活大爆炸版石头剪刀布 http://www.luogu.org/problem/show?pid=1328 这是道大水题,我都在想怎么会有人错了,没算法 ...
- NOIP 2014
Prob.1 生活大爆炸版 石头剪刀布 模拟.代码: #include<cstdio> #include<cstring> #include<iostream> u ...
- Luogu 1351 NOIP 2014 联合权值(贪心,计数原理)
Luogu 1351 NOIP 2014 联合权值(贪心,计数原理) Description 无向连通图 G 有 n 个点,n-1 条边.点从 1 到 n 依次编号,编号为 i 的点的权值为 Wi, ...
随机推荐
- jQuery – 6.选择器
1. 属性过滤选择器: 1. $("div[id]")选取有id属性的<div> 2. $("div[title=test]")选取title属性为 ...
- Tomcat的Session管理机制
>>Session和Cookie请求的过程 Http连接本身是无状态的,即前一次发起的连接跟后一次没有任何关系,是属于两次独立的连接请求,但是互联网访问基本上都是需要有状态的,即服务器需要 ...
- svn删除所有.svn文件
svn 删除所有的 .svn文件 find . -name .svn -type d -exec rm -fr {} \;
- Delphi中函数定义和声明的位置
当函数(或过程)A定义在函数(或过程)B之前,那么函数B就可以调用函数A,并且编译成功,例如下面的 procedure TForm1.btn1Click(Sender: TObject); 和 f ...
- EXCEL中汉字转大写拼音
最近一直没有什么成系统的学习东西,也就没写什么随笔.昨天晚上,一哥们儿说给弄个输入汉字直接转拼音的程序,问了他几点需求,说你想做个啥的,最后,他说想做个EXCEL的,现在发现EXCEL确实是个好东西啊 ...
- 【mysql创建用户|删除用户|修改用户权限|常用命令】
原文链接:http://blog.csdn.net/leili0806/article/details/8573636 1. CREATE USER 语法: CREATE USER 'us ...
- PHP不同域名cookie共享(单点登录实现原理)
PHP使用P3P完成COOKIE跨域操作实际实用中,类似的需求有,比如说我们有两个域名,我们想实现在一个域名登录后,能自动完成另一个域名的登录,也就是单点登录(SSO)功能.为了测试的方便,先编辑ho ...
- jQuery实现长按按钮触发事件的方法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 使用AStyle进行代码格式化
转自:http://www.cnblogs.com/JerryTian/archive/2012/09/20/AStyle.html 在日常的编码当中,大家经常要遵照一些设计规范,如命名规则.代码格式 ...
- JS 时间格式化
Date.prototype.format = function(format){ var o = { "M+" : this.getMonth()+1, //month &quo ...