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, ...
随机推荐
- 与你相遇好幸运,Waterline的多表关联
>一对一关联 表示一个模型可能只与另一个模型关联.为了使模型知道它与其他哪些模型关联,外键必需包含在记录中.. http://imfly.github.io/sails-docs/concept ...
- 没有VisualStudio也要HelloWorld
前言 在博客园看到Artech的通过3个Hello World应用来了解ASP.NET 5应用是如何运行的(1)这篇文章,于是想跟着教程学习一下.说来惭愧,这篇文章发布于2014年12月,我在2016 ...
- HDU5558 Alice's Classified Message(合肥区域赛 后缀数组)
当初合肥区域赛的题(现场赛改了数据范围就暴力过了),可惜当初后缀数组算法的名字都没听过,现在重做下. i从1到n - 1,每次枚举rank[i]附近的排名,并记录当起点小于i时的LCP(rank[i] ...
- C# SMTP邮件发送 分类: C# 2014-07-13 19:10 333人阅读 评论(1) 收藏
邮件发送在网站应用程序中经常会用到,包括您现在看到的博客,在添加评论后,系统会自动发送邮件通知到我邮箱的,把系统发送邮件的功能整理了下,做了一个客户端Demo,希望对有需要的童鞋有所帮助: 核心代码: ...
- JavaScript - BOM
window 对象 window 对象是BOM的核心对象,也是ECMAScript规定的Global对象. 无法跨浏览精确获得窗口左边和上边的精确值,同样也无法确定浏览器窗口本身的大小,但是可以取得页 ...
- Oracle【IT实验室】数据库备份与恢复之二:SQL*Loader
2.1 基本知识 Oracle 的 SQL* LOADER 可以将外部格式化的文本数据加载到数据库表中.通常 与 SPOOL导出文本数据方法配合使用. 1.命令格式 SQLLDR keyw ...
- [Tools] Eclipse更改类注释自动生成模板
[背景] 使用之中发现一些eclipse使用的小技巧,记录下来供以后查阅 由于机器是老婆的,创建新类的时候或者生成注释的时候全都是她的名字,避免弄混,需要设置一下: 设置创建新类时自动生成类或方法 ...
- matlab练习程序(Sepia Tone滤镜)
我手机上有一个软件实现了很多图像滤镜,挺有意思,我打算都尝试一下. 这个滤镜主要是实现老照片效果. 代码很短,我就不详细介绍了. 原图: 处理后效果: matlab代码如下: clear all;cl ...
- bzoj1691[Usaco2007 Dec]挑剔的美食家 平衡树treap
Description 与很多奶牛一样,Farmer John那群养尊处优的奶牛们对食物越来越挑剔,随便拿堆草就能打发她们午饭的日子自然是一去不返了.现在,Farmer John不得不去牧草专供商那里 ...
- zoj 3644(dp + 记忆化搜索)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=4834 思路:dp[i][j]表示当前节点在i,分数为j的路径条数,从 ...