BZOJ.2834.回家的路(最短路Dijkstra 拆点)
对于相邻的、处在同在一行或一列的车站连边,然后用dis[x][0/1](或者拆点)分别表示之前是从横边还是竖边到x的,跑最短路。
我选择拆点。。
//13028kb	604ms
#include <queue>
#include <cstdio>
#include <cctype>
#include <cstring>
#include <algorithm>
//#define gc() getchar()
#define MAXIN 300000
#define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
#define mp std::make_pair
#define pr std::pair<int,int>
const int N=2e5+7,M=N*3,INF=0x3f3f3f3f;
int Enum,H[N],nxt[M],to[M],len[M];
char IN[MAXIN],*SS=IN,*TT=IN;
struct Node
{
	int x,y,id;
}p[N];
inline int read()
{
	int now=0;register char c=gc();
	for(;!isdigit(c);c=gc());
	for(;isdigit(c);now=now*10+c-'0',c=gc());
	return now;
}
bool cmpx(Node a,Node b) {return a.x==b.x?a.y<b.y:a.x<b.x;}
bool cmpy(Node a,Node b) {return a.y==b.y?a.x<b.x:a.y<b.y;}
inline void AE(int u,int v,int w)
{
	to[++Enum]=v, nxt[Enum]=H[u], H[u]=Enum, len[Enum]=w;
	to[++Enum]=u, nxt[Enum]=H[v], H[v]=Enum, len[Enum]=w;
}
void Dijkstra(int s,int t,int n)
{
	static int dis[N];
	static bool vis[N];
	static std::priority_queue<pr> q;
	memset(dis,0x3f,sizeof dis);
	dis[s]=dis[s+n]=0, q.push(mp(0,s)), q.push(mp(0,s+n));
	while(!q.empty())
	{
		int x=q.top().second; q.pop();
		if(vis[x]) continue;
		vis[x]=1;
		for(int i=H[x],v; i; i=nxt[i])
			if(dis[v=to[i]]>dis[x]+len[i])
				q.push(mp(-(dis[v]=dis[x]+len[i]),v));
	}
	printf("%d\n",dis[t]==INF&&dis[t+n]==INF?-1:std::min(dis[t],dis[t+n]));
}
int main()
{
	int m=read(),n=read();//n
	for(int i=1; i<=n; ++i) p[i]=(Node){read(),read(),i};
	p[++n]=(Node){read(),read(),n}, p[++n]=(Node){read(),read(),n};
	std::sort(p+1,p+1+n,cmpx);
	for(int i=2; i<=n; ++i)
		if(p[i].x==p[i-1].x) AE(p[i].id,p[i-1].id,(p[i].y-p[i-1].y)<<1);
	std::sort(p+1,p+1+n,cmpy);
	for(int i=2; i<=n; ++i)
		if(p[i].y==p[i-1].y) AE(p[i].id+n,p[i-1].id+n,(p[i].x-p[i-1].x)<<1);
	for(int i=1; i<=n; ++i) AE(p[i].id,p[i].id+n,1);
	Dijkstra(n-1,n,n);
	return 0;
}
												
											BZOJ.2834.回家的路(最短路Dijkstra 拆点)的更多相关文章
- Bzoj 2834: 回家的路  dijkstra,堆优化,分层图,最短路
		
2834: 回家的路 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 62 Solved: 38[Submit][Status][Discuss] D ...
 - bzoj 2834: 回家的路
		
题目 F.A.Qs Home Discuss ProblemSet Status Ranklist Contest 入门OJ ModifyUser DCOI Logout 捐赠本站 Notice:1 ...
 - BZOJ 2834: 回家的路 Dijkstra
		
按照横,竖为方向跑一个最短路即可,算是水题~ #include <bits/stdc++.h> #define N 200005 #define E 2000000 #define set ...
 - 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第二短路 Dijkstra
		
Description 贝茜把家搬到了一个小农场,但她常常回到FJ的农场去拜访她的朋友.贝茜很喜欢路边的风景,不想那么快地结束她的旅途,于是她每次回农场,都会选择第二短的路径,而不象我们所习惯的那样, ...
 - [SHOI2012]回家的路    最短路
		
---题面--- 题解: 吐槽:找了好久的错,换了n种方法,重构一次代码,,,, 最后发现,,, 数组开小了,其实一开始尝试开大了数组,但唯独没有尝试开大手写队列的数组.... 思路: 有两种方法,这 ...
 - 分层图最短路【bzoj2834】: 回家的路
		
分层图最短路[bzoj2834]: 回家的路 题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2834 这道题难在建边. 自己写的时候想到了 ...
 - 训练指南 UVA - 10917(最短路Dijkstra + 基础DP)
		
layout: post title: 训练指南 UVA - 10917(最短路Dijkstra + 基础DP) author: "luowentaoaa" catalog: tr ...
 - hdu 2544 最短路 Dijkstra
		
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2544 题目分析:比较简单的最短路算法应用.题目告知起点与终点的位置,以及各路口之间路径到达所需的时间, ...
 
随机推荐
- 【逆向工具】IDA使用1-VS2015版本debug查找Main函数,加载符号文件
			
IDA 常见操作 空格,切换反汇编视图 选择CALL或是跳转 进入函数内部或是跳转处 返回键 ESC daq.exe 分析32位程序 ,生成的IDA数据库文件是 .idb Idap64.exe 分析6 ...
 - 【转】Python之装饰器
			
[转]Python之装饰器 本节内容 必要知识回顾 情景模拟 装饰器的概念及实现原理 回马枪(带参数的装饰器) 一. 必要知识回顾 在开始说装饰器之前,需要大家熟悉之前说过的相关知识点: 函数即“变量 ...
 - Python startswith() 函数 判断字符串开头
			
Python startswith() 函数 判断字符串开头 函数:startswith() 作用:判断字符串是否以指定字符或子字符串开头 一.函数说明语法:string.startswith(str ...
 - 再谈:自定义结构体的对齐问题之__attribute__ ((packed))方法【转】
			
转自:https://blog.csdn.net/ipromiseu/article/details/5955295 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.c ...
 - C#实现图片叠加,图片上嵌入文字,文字生成图片的方法
			
/// <summary> /// 图片叠加 /// </summary> /// <param name="sender"& ...
 - ORACLE 利用SCN恢复误delete的表
			
--kg是误删除的表 SQL> select count(*) from kg; COUNT(*) ---------- 820861 SQL> delete from kg; ...
 - Hyper-V虚拟机上安装一个图形界面的Linux系统
			
这件事情呢,一直想干但又觉得太陌生和麻烦,无奈现在到了非装不可的时候,只好硬着头皮去装.在此之前,我不懂什么叫做虚拟机,linux也接触甚少.经过3天的折腾,终于装好了带有图形界面的linux(字符版 ...
 - 转载:gc的概念,如果A和B对象循环引用,是否可以被GC?
			
原文:https://www.cnblogs.com/zhchoutai/p/6784929.html ①首先说一下,GC里边在JVM其中是使用的ROOT算法,ROOT算法,什么称作为ROOT呢,就是 ...
 - android 知识点汇总
			
1.activity 它是 android 应用程序的基本功能单元.一个Activity是一个应用程序组件,提供一个屏幕,用户可以用来交互为了完成某项任务,例如拨号.拍照.Activity 本身是没有 ...
 - CGAffineTransform  缩放 / 旋转 / 平移
			
CGAffineTransform此类是一个3*3矩阵的变换. - (void)transformImageView { CGAffineTransform t = CGAffineTransform ...