Description

Input

Output

Sample Input

2 1
1 2
1 1 2 2

Sample Output

5
 
思路还是很简单的,然而最短路打错各种对拍各种调了一早上
代码:
 #include<iostream>
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
#include<cstdlib>
#include<map>
#include<algorithm>
#define M 300010
using namespace std;
vector<int>S1[M],S2[M];
map<int,int>f[M];
int n,m,num,cnt,x1,x2,y1,y2;
int head[M],dis[M],vis[M],st[M],v[M];
struct point{int to,next,dis;}e[M<<];
void add(int from,int to,int dis) {
e[++num].next=head[from];
e[num].to=to;
e[num].dis=dis;
head[from]=num;
}
void SPFA(int s) {
memset(dis,,sizeof(dis));
queue<int>Q;dis[s]=;
Q.push(s);
while(!Q.empty()) {
int x=Q.front();Q.pop();vis[x]=false;
for(int i=head[x];i;i=e[i].next) {
int to=e[i].to;
if(dis[x]+e[i].dis<dis[to]) {
dis[to]=dis[x]+e[i].dis;
if(!vis[to]) vis[to]=true,Q.push(to);
}
}
}
}
int get(int x,int y) {
return *abs(v[st[x]]-v[st[y]]);
}
bool cmp(int x,int y) {
return v[x]<v[y];
}
int main() {
scanf("%d%d",&n,&m);
for(int i=;i<=m;i++) {
int x,y;scanf("%d%d",&x,&y);
if(f[x][y]!=) continue;
f[x][y]=++cnt;
S1[x].push_back(cnt);v[cnt]=y;
S2[y].push_back(++cnt);v[cnt]=x;
add(cnt-,cnt,),add(cnt,cnt-,);
}
scanf("%d%d%d%d",&x1,&y1,&x2,&y2);
if(!f[x1][y1]) {
f[x1][y1]=++cnt;
S1[x1].push_back(cnt);v[cnt]=y1;
S2[y1].push_back(++cnt);v[cnt]=x1;
add(cnt-,cnt,),add(cnt,cnt-,);
}
else {
int t=f[x1][y1];
add(t+,t,),add(t,t+,);
}
if(!f[x2][y2]) {
f[x2][y2]=++cnt;
S1[x2].push_back(cnt);v[cnt]=y2;
S2[y2].push_back(++cnt);v[cnt]=x2;
add(cnt-,cnt,),add(cnt,cnt-,);
}
else {
int t=f[x2][y2];
add(t+,t,),add(t,t+,);
}
for(int i=;i<=(n<<);i++) {
int tmp=;
for(int j=;j<S1[i].size();j++) st[++tmp]=S1[i][j];
if(tmp>) {
sort(st+,st+tmp+,cmp);
for(int j=;j<=tmp;j++) {
add(st[j-],st[j],get(j-,j));
add(st[j],st[j-],get(j,j-));
}
}
tmp=;
for(int j=;j<S2[i].size();j++) st[++tmp]=S2[i][j];
if(tmp>) {
sort(st+,st+tmp+,cmp);
for(int j=;j<=tmp;j++) {
add(st[j-],st[j],get(j-,j));
add(st[j],st[j-],get(j,j-));
}
}
}
int s=f[x1][y1],t=f[x2][y2];
SPFA(s);
printf("%d\n",dis[t]>1e8?-:dis[t]);
return ;
}

HINT

N<=20000,M<=100000

[BZOJ2834]回家的路的更多相关文章

  1. 分层图最短路【bzoj2834】: 回家的路

    分层图最短路[bzoj2834]: 回家的路 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2834 这道题难在建边. 自己写的时候想到了 ...

  2. Bzoj 2834: 回家的路 dijkstra,堆优化,分层图,最短路

    2834: 回家的路 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 62  Solved: 38[Submit][Status][Discuss] D ...

  3. bzoj 2834: 回家的路

    题目 F.A.Qs Home Discuss ProblemSet Status Ranklist Contest 入门OJ ModifyUser  DCOI Logout 捐赠本站 Notice:1 ...

  4. P3831 [SHOI2012]回家的路

    P3831 [SHOI2012]回家的路 分层图基础题,就是建图稍有麻烦   #include<cstdio> #include<algorithm> #include< ...

  5. 【bzoj2834】回家的路 分层图最短路

    题目描述 输入 输出 样例输入 2 1 1 2 1 1 2 2 样例输出 5 题解 分层图最短路 dis[i][0]表示到i为横向时起点到i的最短路,dis[i][1]表示到i为纵向时起点到i的最短路 ...

  6. [SHOI2012]回家的路

    题目背景 SHOI2012 D2T1 题目描述 2046 年 OI 城的城市轨道交通建设终于全部竣工,由于前期规划周密,建成后的轨道交通网络由2n2n条地铁线路构成,组成了一个nn纵nn横的交通网.如 ...

  7. [SHOI2012]回家的路 最短路

    ---题面--- 题解: 吐槽:找了好久的错,换了n种方法,重构一次代码,,,, 最后发现,,, 数组开小了,其实一开始尝试开大了数组,但唯独没有尝试开大手写队列的数组.... 思路: 有两种方法,这 ...

  8. 洛谷P3831 回家的路

    题目背景 SHOI2012 D2T1 题目描述 \(2046\) 年 \(OI\) 城的城市轨道交通建设终于全部竣工,由于前期规划周密,建成后的轨道交通网络由\(2n\)条地铁线路构成,组成了一个\( ...

  9. BZOJ.2834.回家的路(最短路Dijkstra 拆点)

    题目链接 对于相邻的.处在同在一行或一列的车站连边,然后用dis[x][0/1](或者拆点)分别表示之前是从横边还是竖边到x的,跑最短路. 我选择拆点.. //13028kb 604ms #inclu ...

随机推荐

  1. MQTT 3.1协议非严肃反思录

    前言 MQTT 3.1协议在弱网络环境下(比如2G/3G等)表现不够好,因此才有了反思. 弱网环境下表现 手机等终端在弱网络环境下丢包情况会非常明显,连接MQTT Server成功率很低.相比单纯的请 ...

  2. 【WebService】使用jaxb完成对象和xml的转换

    package com.slp.jxmarshaller; /** * Created by sanglp on 2017/2/26. */ public class ClassName { priv ...

  3. AOP学习总结

    参考:什么是AOP? OOP引入封装.继承和多态性等概念来建立一种对象层次结构,用以模拟公共行为的一个集合.当我们需要为分散的对象引入公共行为的时候,OOP则显得无能为力.也就是说,OOP允许你定义从 ...

  4. Vue 学习顺序

    起步: 1.扎实的 JavaScript / HTML / CSS 基本功,ES6 最好过一遍 2.通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script&g ...

  5. 170620、springboot编程之页面版Hello World

    书接上回,把Hello World 在页面上显示! 1.在pom文件中加入web支持 <dependency> <groupId>org.springframework.boo ...

  6. 组织机构代码校验码生成算法(C#版)

    using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...

  7. Wormholes---poj3259(最短路 spfa 判断负环 模板)

    题目链接:http://poj.org/problem?id=3259 题意是问是否能通过虫洞回到过去: 虫洞是一条单向路,不但会把你传送到目的地,而且时间会倒退Ts. 我们把虫洞看成是一条负权路,问 ...

  8. marathon-lb-什么是服务发现?(转)

    摘要: 将容器应用部署到集群时,其服务地址,即IP和端口, 是由集群系统动态分配的.那么,当我们需要访问这个服务时,如何确定它的地址呢?这时,就需要服务发现(Service Discovery)了.本 ...

  9. java多线程(四)

    使用synchronized锁实现线程同步 为什么要用线程同步 我们先来看下这段代码的运行结果: Java学习交流群:495273252 在多线程上篇博客已经介绍过了,JVM采用的是抢占式调度模型,当 ...

  10. docker——核心实现技术

    作为一种容器虚拟化技术,Docker深度应用了操作系统的多项底层支持技术. 早期版本的Docker是基于已经成熟的Linux Container(LXC)技术实现的.自从0.9版本起,Docker逐渐 ...