jzoj3086 [分層圖最短路]
分層圖最短路即可
#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 [分層圖最短路]的更多相关文章
- 修練營ASP.NET]淺談多層式架構 (Multi Tiers)
從需求談起 我們舉個小例子來理解一般的方式與多層的方式有何不同 假設:我需要顯示最近三個月內,所有營業員的銷售金額成績排名 一般的做法: 在一個畫面中,拉個GridView,一個SqlDataSouc ...
- [題解]luogu_P1144最短路計數
1.無權圖最短路邊權為1 2.如果兩個點恰好不能被更新(d[y]==d[x]+1)那麼就能通過x的所有最短路到達y,所以ans[y]+=ans[x] 3.如果兩個點不能恰好被更新(d[y]>d[ ...
- Codeforces C. Jzzhu and Cities(dijkstra最短路)
题目描述: Jzzhu and Cities time limit per test 2 seconds memory limit per test 256 megabytes input stand ...
- 淺談 Entity 的概念
延續上一篇文章<Drupal Commerce 概念架構>,本來打算要繼續講 Commerce 與 Views 整合的主題.不過由於這個主題牽涉到 Views 中的 Relationshi ...
- AORUS GA-Z270X-Gaming 5開箱
「AORUS」這個品牌名稱由埃及神祇荷魯斯(戰爭與狩獵之神)的名字衍生而成.荷魯斯通常被勾勒為獵鷹的形象,因此獵鷹的頭形被用作AORUS品牌的商標於2014年,本來只做為用在電競筆電及一些週邊方面,但 ...
- 【WIN10】程序內文件讀取與保存
DEMO下載:http://yunpan.cn/cFHIZNmAy4ZtH 访问密码 cf79 1.讀取與保存文件 Assets一般被認為是保存用戶文件數據的地方.同時,微軟還支持用戶自己創建文件夾 ...
- Visual Studio 跨平台開發實戰(2) - Xamarin.iOS 基本控制項介紹 (转帖)
前言 在上一篇文章中, 我們介紹了Xamarin 以及簡單的HelloWorld範例, 這次我們針對iOS的專案目錄架構以及基本控制項進行說明. 包含UIButton,, UISlider, UISw ...
- Visual Studio 跨平台開發實戰(1) - Hello Xamarin! (转帖)
前言 應用程式發展的腳步, 從來沒有停過. 從早期的Windows 應用程式, 到網路時代的web 應用程式, 再到近幾年相當盛行的行動裝置應用程式(Mobile Application), 身為C# ...
- Visual Studio + C# + Xamarin = iOS/Android/Windows Apps
Visual Studio 跨平台開發實戰 (1) -- Hello Xamarin! 前言 應用程式發展的腳步,從來沒有停過.從早期的 Windows 應用程式, 到網路時代的 web 應用程式,再 ...
随机推荐
- 【搜索】Fliptile
#include<stdio.h> #include<stdlib.h> #include<string.h> ; ; typedef long long ll; ...
- spring学习 四 对象的创建
spring中,有三种创建对象的方式 (1)构造创建 (2)实例工厂构造 (3)静态工厂构造 一 构造器创建 在构造器创建对象时,有无参构造和有参构造 两种 (1)在spring中,默认的是无参构造 ...
- 过河卒(NOIP2002)
题目链接:过河卒 直接模拟?会T掉60分. 所以我们可以采用递推,怎么想到的? 因为卒子只能向下或向右走,所以走到一个点的方法数,等于走到它上面点的方法数加上走到它左边点的方法数,这样就可以地推了. ...
- LCA(最近公共祖先)模板
Tarjan版本 /* gyt Live up to every day */ #pragma comment(linker,"/STACK:1024000000,1024000000&qu ...
- 常用模块 plus
一.os 模块 1. os os.makedirs 创建多级目录 os.mkdir 只能创建一层 如果是多层,上层文件夹必须存在 os.removedirs 删除目录集中所有空文件夹 os.rm ...
- js监听键盘触发按钮事件,回车提交表单
/*回车提交表单*/ $(document).keydown(function(event){ if(event.keyCode == 13){ //alert('你按下了Enter'); $(&qu ...
- 容器,表格 ,div,元素可左右拖动,滚动 css
<!DOCTYPE html> <html lang="en"> <head> <meta charset="utf-8&quo ...
- Effective C++ 随笔(1)
条款一 c++ 为一个语言联邦 1.四个层次 C:blocks,语句,预处理器,内置数据类型,数组,指针 面向对象的C++:封装,多态,继承 Template C++ STL 条款二 尽量以const ...
- 解决编译错误:cc: Internal error: Killed (program cc1)
错误现象: cc: Internal error: Killed (program cc1) ... 大体上是因为内存不足,临时使用交换分区来解决吧 sudo mkswap /swapfile sud ...
- 【笔记】CSS选择器整理(IE低版本支持性测试)
时间:2015.05.11 参考附件:css选择器.xmind(网友共享) 查看链接:http://www.w3school.com.cn/cssref/css_selectors.asp htt ...