(又是昨天的作业……本题写于昨天)

(这破题都做这么久,我是不是吃枣药丸……)

(好吧这是一道图论题呢)

本题地址:http://www.luogu.org/problem/show?pid=2296

题目描述

在有向图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。

------------------------------您的好友分割线菌正在登录中----------------------------------------------------------------------------------------------------

题意要理解对啊

首先得去掉不能去的点,dfs就行了

大概输入时存一个反图,然后把反图中从终点不能到的点标记,再把这些点反图中出边连着的点在正图中去掉就好了(只需去掉直接相连点的哈)

接着上最短路(SPFA真的比dij快吗)

大水题,我果然要完……

 #include<stdio.h>
#include<stdlib.h>
#include<string.h>
typedef struct{
int to;
int next;
}line;
line gra[],shg[];
int head[]={},shh[]={},num=,note[]={};
int n,m;/*n个点,m条边*/
int s,t;
int dis[],que[]={},pos[]={};
int add(int from,int to){
num++;
gra[num].next=head[from];
gra[num].to=to;
head[from]=num;
shg[num].next=shh[to];
shg[num].to=from;
shh[to]=num;
return ;
}
int point(int goal){
int l=shh[goal];
while(l!=){
if(note[shg[l].to]==){
note[shg[l].to]=;
point(shg[l].to);
}
l=shg[l].next;
}
return ;
}
int shut(){
int i=;
while(i<=n){
if(note[i]==&&i!=t){
int l=shh[i];
while(l!=){
head[shg[l].to]=;
l=shg[l].next;
}
}
i++;
}
return ;
}
int spfa(){
for(int i=;i<=n;i++) dis[i]=;
int l,he=,tail=;
dis[s]=;
que[he]=s;
pos[s]=;
do{
l=head[que[he]];
while(l!=){
if(dis[gra[l].to]>=dis[que[he]]+){
dis[gra[l].to]=dis[que[he]]+;
if(pos[gra[l].to]==){
tail++;
que[tail]=gra[l].to;
pos[gra[l].to]=;
}
}
l=gra[l].next;
}
he++;
}while(he<=tail);
if(dis[t]==) return -;
else return dis[t];
}
int main(){
scanf("%d %d",&n,&m);
for(int i=;i<=m;i++){
scanf("%d %d",&s,&t);
add(s,t);
}
scanf("%d %d",&s,&t);
point(t);
shut();
if(note[s]==){
printf("-1");
return ;
}
//for(int i=1;i<=n;i++) printf("%d ",note[i]);
printf("%d",spfa());
return ;
}

noip2014提高组day2二题题解-rLq的更多相关文章

  1. NOIP 2008提高组第三题题解by rLq

    啊啊啊啊啊啊今天已经星期三了吗 那么,来一波题解吧 本题地址http://www.luogu.org/problem/show?pid=1006 传纸条 题目描述 小渊和小轩是好朋友也是同班同学,他们 ...

  2. NOIP提高组历年真题题解

    2018 铺设道路 差分水题,推一下结论就好了. #include<cstdio> #include<algorithm> using namespace std; ],d[] ...

  3. NOIp2014提高组初赛错题简析

    总体分析 \(89pts\),粗略来看选择题错的比较多,\(-6pts\).同时又是尿性的填空杀扣了\(5pts\). 不过后面的两大题全对了还是可喜可贺 错题精析 单项选择T8 编译器的主要功能是( ...

  4. 【DFS】【最短路】【spfa】【BFS】洛谷P2296 NOIP2014提高组 day2 T2 寻找道路

    存反图,从终点dfs一遍,记录下无法到达的点. 然后枚举这些记录的点,把他们的出边所连的点也全部记录. 以上这些点都是无法在最短路中出现的. 所以把两个端点都没被记录的边加进图里,跑spfa.BFS什 ...

  5. 【暴力】洛谷 P2038 NOIP2014提高组 day2 T1 无线网络发射器选址

    暴力枚举. #include<cstdio> #include<algorithm> using namespace std; ][],d,n,x,y,z,num,ans=-; ...

  6. 刷题总结——飞扬的小鸟(NOIP2014提高组)

    题目: 题目背景 NOIP2014 提高组 Day1 试题. 题目描述 Flappy Bird 是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面 ...

  7. NOIP提高组2004 合并果子题解

    NOIP提高组2004 合并果子题解 描述:在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消 ...

  8. [DP]Luogu 2014NOIP提高组 飞扬的小鸟题解

    2014NOIP提高组飞扬的小鸟题解 题目描述 Flappy Bird是一款风靡一时的休闲手机游戏.玩家需要不断控制点击手机屏幕的频率来调节小鸟的飞行高度,让小鸟顺利通过画面右方的管道缝隙.如果小鸟一 ...

  9. 18/9/16牛客网提高组Day2

    牛客网提高组Day2 T1 方差 第一眼看就知道要打暴力啊,然而并没有想到去化简式子... 可能因为昨晚没睡好,今天上午困死 导致暴力打了一个半小时,还不对... #include <algor ...

随机推荐

  1. 【Bootstrap基础学习】02 Bootstrap的布局组件应用示例

    字体图标的应用示例 <button type="button" class="btn btn-default"> <span class=&q ...

  2. 晒自己做的一个管理系统(清新风格)EasyUI

    最近项目结束了,现在也要自己总结一下自己的成果了,总结会加深自己对项目的印象的.这里我就先晒一些作品图片了,希望大家看了会赞美一个! 项目虽然结束了,但是接下来的这个项目可就不是我一个人可以搞定的了, ...

  3. 【BZOJ 4326】【NOIP2015】运输计划

    http://www.lydsy.com/JudgeOnline/problem.php?id=4326 题目描述 公元2044年,人类进入了宇宙纪元. 国有个星球,还有条双向航道,每条航道建立在两个 ...

  4. WCF服务部署到IIS7.5

    下面介绍如何把WCF服务部署到IIS: 为WCF服务创建.svc文件 我们知道,每一个ASP.NET Web服务都具有一个.asmx文本文件,客户端通过访问.asmx文件实现对相应Web服务的调用.与 ...

  5. Virtual DOM 算法

    前端 virtual-dom react.js javascript 目录: 1 前言 2 对前端应用状态管理思考 3 Virtual DOM 算法 4 算法实现 4.1 步骤一:用JS对象模拟DOM ...

  6. How to copy files between sites using JavaScript REST in Office365 / SharePoint 2013

    http://techmikael.blogspot.in/2013/07/how-to-copy-files-between-sites-using.html I'm currently playi ...

  7. 转:NLog 自定义日志内容,写日志到数据库;修改Nlog.config不起作用的原因

    转:http://www.cnblogs.com/tider1999/p/4308440.html NLog的安装请百度,我安装的是3.2.NLog可以向文件,数据库,邮件等写日志,想了解请百度,这里 ...

  8. ADB server didn't ACK 解决方法

    在安卓开发的过程中 连接真机的时候 连接不上 提示 The connection to adb is down, and a severe error has occured.[2015-01-22 ...

  9. Android中TextView中的文字设置为不同颜色

    questionDesTextView=(TextView)findViewById(R.id.question_des); SpannableStringBuilder builder = new ...

  10. 使用 SharedPreferences 实现数据的存储和读取

    在开发的过程中我们必须遇到的就是如何对用户的数据进行有效的存储以及读取.我们举个例子,现在我们使用app,当我们登陆一个账号的时候选择记住密码软件就会记住我们的账号以及密码,我们退出当前账号,就可以直 ...