分層圖最短路即可

#include<bits/stdc++.h>
using namespace std;
#define N 1000010
int n,m,v[N*2],nxt[N*2],w[N*2],h[N],ec,d[N],vis[N],s,t,x[N],y[N],sx,sy,tx,ty;
void add(int x,int y,int z){v[++ec]=y;w[ec]=z;nxt[ec]=h[x];h[x]=ec;}
void bfs(){
	queue<int>q;
	q.push(s);
	vis[s]=1;
	memset(d,63,sizeof(d));
	d[s]=0;
	while(!q.empty()){
		int x=q.front();
		q.pop();
		vis[x]=0;
		for(int i=h[x];i;i=nxt[i])
			if(d[v[i]]>d[x]+w[i]){
				d[v[i]]=d[x]+w[i];
				if(!vis[v[i]]){
					vis[v[i]]=1;
					q.push(v[i]);
				}
			}
	}
}
bool c1(int a,int b){return y[a]<y[b];}
bool c2(int a,int b){return x[a]<x[b];}
vector<int>vc[100010];
int main(){
	scanf("%d%d",&n,&m);
	for(int i=1;i<=m;i++)
		scanf("%d%d",&x[i],&y[i]);
	for(int i=1;i<=m;i++)
		vc[x[i]].push_back(i);
	for(int i=1;i<=n;i++)
		sort(vc[i].begin(),vc[i].end(),c1);
	for(int i=1;i<=n;i++)
		for(int j=0;j<vc[i].size();j++)
			if(j!=vc[i].size()-1){
				int a=vc[i][j],b=vc[i][j+1];
				add(a*2-1,b*2-1,abs(y[a]-y[b])*2);
				add(b*2-1,a*2-1,abs(y[a]-y[b])*2);
			}
	for(int i=1;i<=n;i++)
		vc[i].clear();
	for(int i=1;i<=m;i++)
		vc[y[i]].push_back(i);
	for(int i=1;i<=n;i++)
		sort(vc[i].begin(),vc[i].end(),c2);
	for(int i=1;i<=n;i++)
		for(int j=0;j<vc[i].size();j++)
			if(j!=vc[i].size()-1){
				int a=vc[i][j],b=vc[i][j+1];
				add(a*2,b*2,abs(x[a]-x[b])*2);
				add(b*2,a*2,abs(x[a]-x[b])*2);
			}
	for(int i=1;i<=m;i++){
		add(i*2,i*2-1,1);
		add(i*2-1,i*2,1);
	}
	scanf("%d%d%d%d",&sx,&sy,&tx,&ty);
	s=m*2+3;t=m*2+4;
	for(int i=1;i<=m;i++){
		if(sy==y[i])add(s,i*2,abs(sx-x[i])*2);
		if(sx==x[i])add(s,i*2-1,abs(sy-y[i])*2);
	}
	for(int i=1;i<=m;i++){
		if(tx==x[i])add(i*2-1,t,abs(ty-y[i])*2);
		if(ty==y[i])add(i*2,t,abs(tx-x[i])*2);
	}
	bfs();
	printf("%d",d[t]>1000000000?-1:d[t]);
}

jzoj3086 [分層圖最短路]的更多相关文章

  1. 修練營ASP.NET]淺談多層式架構 (Multi Tiers)

    從需求談起 我們舉個小例子來理解一般的方式與多層的方式有何不同 假設:我需要顯示最近三個月內,所有營業員的銷售金額成績排名 一般的做法: 在一個畫面中,拉個GridView,一個SqlDataSouc ...

  2. [題解]luogu_P1144最短路計數

    1.無權圖最短路邊權為1 2.如果兩個點恰好不能被更新(d[y]==d[x]+1)那麼就能通過x的所有最短路到達y,所以ans[y]+=ans[x] 3.如果兩個點不能恰好被更新(d[y]>d[ ...

  3. Codeforces C. Jzzhu and Cities(dijkstra最短路)

    题目描述: Jzzhu and Cities time limit per test 2 seconds memory limit per test 256 megabytes input stand ...

  4. 淺談 Entity 的概念

    延續上一篇文章<Drupal Commerce 概念架構>,本來打算要繼續講 Commerce 與 Views 整合的主題.不過由於這個主題牽涉到 Views 中的 Relationshi ...

  5. AORUS GA-Z270X-Gaming 5開箱

    「AORUS」這個品牌名稱由埃及神祇荷魯斯(戰爭與狩獵之神)的名字衍生而成.荷魯斯通常被勾勒為獵鷹的形象,因此獵鷹的頭形被用作AORUS品牌的商標於2014年,本來只做為用在電競筆電及一些週邊方面,但 ...

  6. 【WIN10】程序內文件讀取與保存

    DEMO下載:http://yunpan.cn/cFHIZNmAy4ZtH  访问密码 cf79 1.讀取與保存文件 Assets一般被認為是保存用戶文件數據的地方.同時,微軟還支持用戶自己創建文件夾 ...

  7. Visual Studio 跨平台開發實戰(2) - Xamarin.iOS 基本控制項介紹 (转帖)

    前言 在上一篇文章中, 我們介紹了Xamarin 以及簡單的HelloWorld範例, 這次我們針對iOS的專案目錄架構以及基本控制項進行說明. 包含UIButton,, UISlider, UISw ...

  8. Visual Studio 跨平台開發實戰(1) - Hello Xamarin! (转帖)

    前言 應用程式發展的腳步, 從來沒有停過. 從早期的Windows 應用程式, 到網路時代的web 應用程式, 再到近幾年相當盛行的行動裝置應用程式(Mobile Application), 身為C# ...

  9. Visual Studio + C# + Xamarin = iOS/Android/Windows Apps

    Visual Studio 跨平台開發實戰 (1) -- Hello Xamarin! 前言 應用程式發展的腳步,從來沒有停過.從早期的 Windows 應用程式, 到網路時代的 web 應用程式,再 ...

随机推荐

  1. 可以用WebRTC来做视频直播吗?

    https://www.zhihu.com/question/25497090   作者:韦易笑链接:https://www.zhihu.com/question/25497090/answer/72 ...

  2. canvas和图片互转

    原文:http://www.jb51.net/html5/160920.html 这么神奇么?先记录一下. 使用JavaScript将图片拷贝进画布 要想将图片放入画布里,我们使用canvas元素的d ...

  3. 2017年多校get点

    杨辉三角形变形??? lucas定理

  4. centos6 搭建nginx实现负载均衡

    一.安装nginx 1)准备2台服务器,环境一样,同时执行 rpm -ivh http://mirrors.aliyun.com/epel/epel-release-latest-6.noarch.r ...

  5. css兼容技巧

    CSS兼容常用技巧 请尽量用xhtml格式写代码,而且DOCTYPE影响 CSS 处理,作为W3C标准,一定要加DOCTYPE声明. 1.div的垂直居中问题 vertical-align:middl ...

  6. 2019.01.16 bzoj3526: [Poi2014]Card(线段树)

    传送门 线段树菜题. 题意:有一些卡牌,正反各有一个数,你可以任意翻转,每次操作会将两张卡牌的位置调换,你需要在每次操作后回答以现在的卡牌顺序能否通过反转形成一个单调不降的序列. 思路: 对于一个线段 ...

  7. 2018.10.31 NOIP训练 锻造(方程式期望入门题)(期望dp)

    传送门 根据题目列出方程: fi=pi∗(fi−1+fi−2)+(1−pi)∗(fi+1+fi)f_i=p_i*(f_{i-1}+f_{i-2})+(1-p_i)*(f_{i+1}+f_i)fi​=p ...

  8. IntelliJ IDEA 2017版 SpringBoot测试类编写

    SpringBoot的测试类编写Demo 源码见 https://github.com/liushaoye/baseone.git

  9. 访问前台页面${pageContext.request.contextPath}/el表达式失效问题解决

    访问前台页面${pageContext.request.contextPath}/el表达式失效问题解决 2017年05月09日 10:54:18 AinUser 阅读数:922 标签: el表达式4 ...

  10. Calendar 得到前一天当前时间

    @Test public void test(){ //因为Calendar的构造方法是私有的,所以实例化一个Calendar对象用getInstance方法 Calendar calendar = ...