bzoj1726 第二短路
一道严格次短路题,WA了一下午回家才发现bellman_ford中的vis [ o ] = false 写成了 vis [ S ] = false.被自己脑残了一脸。。。。
#include<climits>
#include<cstdio>
#include<algorithm>
#include<queue>
using namespace std ; void min_equal ( int & a , const int b ) {
if ( a > b ) a = b ;
} const int MAXN = + ;
const int MAXR = + ; struct edge {
int dis ;
int p ;
edge * next ;
} ; edge * V [ MAXN ] ;
edge E [ MAXR * ] ; void add_edge ( const int a , const int b , const int dis ) {
static edge * t = E ;
edge * x = t ++ , * y = t ++ ;
x -> dis = y -> dis = dis ;
x -> p = b ; y -> p = a ;
x -> next = V [ a ] ; y -> next = V [ b ] ;
V [ a ] = x ; V [ b ] = y ;
} int N , R ;
int dis1 [ MAXN ] ;
int dis2 [ MAXN ] ; void bellman_ford ( const int S , const int T , int dis [] ) {
static int vis [ MAXN ] ;
static const int INF = INT_MAX ;
static queue < int > q ;
fill ( dis , dis + N + , INF ) ;
fill ( vis , vis + N + , ) ;
dis [ S ] = ;
vis [ S ] = true ;
q . push ( S ) ;
while ( ! q . empty () ) {
const int o = q . front () ;
q . pop () ;
vis [ o ] = false ;
for ( edge * v = V [ o ] ; v != ; v = v -> next )
if ( dis [ o ] + v -> dis < dis [ v -> p ] ) {
dis [ v -> p ] = dis [ o ] + v -> dis ;
if ( ! vis [ v -> p ] ) {
vis [ v -> p ] = true ;
q . push ( v -> p ) ;
}
}
}
} int main () {
scanf ( "%d%d" , & N , & R ) ;
while ( R -- ) {
int a , b , c ;
scanf ( "%d%d%d" , & a , & b , & c ) ;
add_edge ( a , b , c ) ;
}
bellman_ford ( , N , dis1 ) ;
bellman_ford ( N , , dis2 ) ;
int ans = INT_MAX ;
for ( int i = ; i <= N ; ++ i )
for ( edge * v = V [ i ] ; v != ; v = v -> next ) {
const int a = dis1 [ i ] + v -> dis + dis2 [ v -> p ] ;
if ( a != dis1 [ N ] ) min_equal ( ans , a ) ;
}
printf ( "%d\n" , ans ) ;
return ;
}
bzoj1726 第二短路的更多相关文章
- BZOJ1726: [Usaco2006 Nov]Roadblocks第二短路
1726: [Usaco2006 Nov]Roadblocks第二短路 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 768 Solved: 369[S ...
- BZOJ1726: [Usaco2006 Nov]Roadblocks第二短路 K短路
Description 贝茜把家搬到了一个小农场,但她常常回到FJ的农场去拜访她的朋友.贝茜很喜欢路边的风景,不想那么快地结束她的旅途,于是她每次回农场,都会选择第二短的路径,而不象我们所习惯的那样, ...
- 最短路【bzoj1726】: [Usaco2006 Nov]Roadblocks第二短路
1726: [Usaco2006 Nov]Roadblocks第二短路 Description 贝茜把家搬到了一个小农场,但她常常回到FJ的农场去拜访她的朋友.贝茜很喜欢路边的风景,不想那么快地结束她 ...
- Bzoj 1726: [Usaco2006 Nov]Roadblocks第二短路 dijkstra,堆,A*,次短路
1726: [Usaco2006 Nov]Roadblocks第二短路 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 969 Solved: 468[S ...
- BZOJ 1726: [Usaco2006 Nov]Roadblocks第二短路( 最短路 )
从起点和终点各跑一次最短路 , 然后枚举每一条边 , 更新answer ---------------------------------------------------------------- ...
- BZOJ 1726: [Usaco2006 Nov]Roadblocks第二短路
1726: [Usaco2006 Nov]Roadblocks第二短路 Description 贝茜把家搬到了一个小农场,但她常常回到FJ的农场去拜访她的朋友.贝茜很喜欢路边的风景,不想那么快地结束她 ...
- 1726: [Usaco2006 Nov]Roadblocks第二短路
1726: [Usaco2006 Nov]Roadblocks第二短路 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 835 Solved: 398[S ...
- [模板] 次短路 | bzoj1726-[Usaco2006Nov]Roadblocks第二短路
简介 所谓次短路, 顾名思义, 就是第二短路. :P 1到n的次短路长度必然产生于:1到x的最短路 + edge(x,y) + y到n的最短路 简单证明一下: 设 \(dis(i,j)\) 表示 \( ...
- [Usaco2006 Nov]Roadblocks第二短路
贝茜把家搬到了一个小农场,但她常常回到FJ的农场去拜访她的朋友.贝茜很喜欢路边的风景,不想那么快地结束她的旅途,于是她每次回农场,都会选择第二短的路径,而不象我们所习惯的那样,选择最短路. 贝茜所在的 ...
随机推荐
- JAVA日期类图解
- 【redis常用的键值操作及性能优化】
服务端 启动redis服务 { // -a:指定密码 -h:指定主机 -p:指定端口 } //让redis 服务中断崩溃 //保存和关闭 //后台备份 //设置登录密码 //redis-benchma ...
- JS高级. 03 混入式继承/原型继承/经典继承、拓展内置对象、原型链、创建函数的方式、arguments、eval、静态成员、实例成员、instanceof/是否在同一个原型链
继承:当前对象没有的属性和方法,别人有,拿来给自己用,就是继承 1 混入式继承 var I={ }; var obj = { name: 'jack', age:18, sayGoodbye : fu ...
- Javaweb——四则运算---18.11.01
---恢复内容开始--- test.jsp <%@ page language="java" contentType="text/html; charset=utf ...
- 初步学习pg_control文件之四
接前文,初步学习pg_control文件之三 继续分析 何时出现 DB_SHUTDOWNING状态: 在正常的shutdown的时候,需要进行checkpoint,所以就在此处,设置pg_contr ...
- Windows扩展屏开发总结
本文来自网易云社区 作者:梁敏 一.多屏设置 在设置-系统-可以点击显示器1和2,可以进行单独设置: "使之成为我的主显示器"可以设置当前显示器是主屏:主屏的选择会决定整个虚拟屏幕 ...
- MySQL源码中的String
适用于离开作用域就销毁的字符串.
- Scala function programming
1. Arbitrary multi parameters funcs sum(1,2,3,4,5) = sum(1 to 5: _*)the equal '=' can be ignored if ...
- 玩转Vim-札记(二)
玩转Vim-札记(二) 距上篇博文已有一周有余,上次主要介绍了编辑器之神Vim的起源.安装并介绍了两种模式以及一些简单的操作.本次将继续对Vim的使用进行介绍. 登堂入室 首先接着说移动吧: 0 → ...
- python QQ邮箱自动发送邮件
于初学者来讲在写发送邮件代码时常见的错误有SMTPAuthenticationError535,有点懵逼,检查用户名,密码正确就是报错, 想当年笔者也是这么过来的,现在就给大家分享一下个人经验: 一, ...