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第三方库生成二维码
本文主要介绍两个可用于生成二维码的Python第三方库:MyQR和qrcode. MyQR的使用: 安装: pip install MyQR 导入: from MyQR import myqr imp ...
- Python练习笔记(2)
文件读写,多线程.多进程 import time,os,threading,random def file_read(path): try: with open(path, 'r') as f: # ...
- NAND Flash结构及驱动函数
目标:以NAND Flash K9F2G08U0M为例介绍其结构及其驱动程序的书写 1. 结构 由芯片手册中的图可知:K9F2G08U0M大小为2112Mbits(即 256MB = 2Gb ) 共有 ...
- QOS-Qos标记和QOS-Policy策略
QOS-Qos标记和qos policy策略 2018年7月7日 20:29 主要标记方法 : IP ToS字段标记 IP Precedence(IP优先级) DSCP 二层 802.1p CoS ...
- 也谈js传值和传址
通常的认识就是基本的数值元素是传值,对象等复杂结构传址,无需争论,一试便知. 首先是数值 var a = 1 var b = a a = 2 console.log(a) console.log(b) ...
- Linux下中文乱码问题
记录一下配置centos的时候遇到的一些常见问题 写了一个python脚本,有中文注释,而且会输出一些用户名称,其中包含中文字符.显示的时候出现乱码. 解决方案: 参见博客: Linux基础:中文显示 ...
- Django信号的使用
https://www.cnblogs.com/renpingsheng/p/7566647.html
- vuex的使用及持久化state的方式详解
vuex的使用及持久化state的方式详解 转载 更新时间:2018年01月23日 09:09:37 作者:baby格鲁特 我要评论 这篇文章主要介绍了vuex的使用及持久化state的方 ...
- quartz 使用总结
quartz是一个任务调度框架,具体的用途比如说,我想我的程序在每天的3点干什么事,每隔多长时间做一件什么事.quartz框架就可以完美地解决这些. 1.xml配置方式 首先我是用spring来管理的 ...
- LR创建数据源读取excel
1 在window上创建数据源 2 创建对应的数据文件 excel 注:注意格式和底部的表单名称 3 Vegen中创建参数 注意:机器数据源选择windows的ODBC数据源 SQL查的是(she ...