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的农场去拜访她的朋友.贝茜很喜欢路边的风景,不想那么快地结束她的旅途,于是她每次回农场,都会选择第二短的路径,而不象我们所习惯的那样,选择最短路. 贝茜所在的 ...
随机推荐
- python的pymysql模块简介
一.介绍 在python中用pymysql模块来对mysql进行操作,该模块本质就是一个套接字客户端软件,使用前需要事先安装 pip3 install pymysql 二.操作简介 import py ...
- jquery点击按钮复制内容
做移动端的项目遇到一个需求要点击按钮复制dom里的内容,看了很多资料显示必须textarea或者input里的内容才能简单复制,还有就是用插件的了,最终都因为遇到各种问题放弃,最终选择了最简单的点击复 ...
- 【ISIS(中间系统到中间系统)路由链路状态信息协议初识】
ISIS单区域的基本配置 一:根据项目需求,考虑到组网的规模和条件,部署ISIS单区域的拓扑图如下: 二:配置 1:首先对RTA进行配置,在系统视图创建ISIS进程:进入ISIS配置视图,指定IS的级 ...
- 微信小程序 提示框延时跳转
wx.showToast({ title: '成功', icon: 'success', duration: 2000, success:function(){ console.log('haha') ...
- backtrace函数
1.函数原型 #include <execinfo.h> int backtrace(void **buffer, int size); 该函数获取当前线程的调用堆栈,获取的信息将会被存放 ...
- Go语言获取本地IP地址
最近要做一个向局域网内的所有设备广播发送信息,并接受设备的回复信息,回复信息包括设备的版本号,IP地址,运行工程名等信息.发现一个局域网内是可以有不同的网段的,但UDP广播只能是同一个网段的广播.又发 ...
- 【转】让Moodle支持多个域名
默认情况下,moodle仅能绑定一个域名.但是由于学校网络分内网和外网,总希望如果是外网访问的,用外网的域名,用内网访问的,就转到内网的ip.这样访问的速度会更快一些,也减低对防火墙的压力.尤其是当外 ...
- 10-mongodb启动错误
1.error信息 python@ubuntu:~$ mongod --22T17:: I CONTROL [initandlisten] MongoDB starting : pid= port= ...
- centos7下安装elasticSearch错误总结(单节点模式)
1.首先确定你安装了jdk,版本需要1.8以上 2.上传elasticsearchjar包,只需配置一个文件即可 修改配置文件config/elasticsearch.yml network.h ...
- 【MVC】 小问题
[MVC] 小问题 1. url 传参中文乱码 : encodeURIComponent 转码 2. RedirectToAction 重定向 : ajax 调用无效, 直接 url 访问有效 3. ...