BZOJ2069: [POI2004]ZAW
2069: [POI2004]ZAW
Time Limit: 10 Sec Memory Limit: 64 MB
Submit: 303 Solved: 138
[Submit][Status][Discuss]
Description
Byte山的山脚下有一个洞穴入口. 这个洞穴由复杂的洞室经过隧道连接构成. 洞穴的入口是一条笔直通向“前面洞口”的道路.
隧道互相都不交叉(他们只在洞室相遇). 两个洞室要么就通过隧道连接起来,要么就经过若干隧道间接的相连.
现在决定组织办一个'King's of Byteotia Cup' 比赛. 参赛者的目标就是任意选择一条路径进入洞穴并尽快出来即可.
一条路径必须经过除了“前面洞口”之外还至少要经过其他一个洞室.一条路径中一个洞不能重复经过(除了“前面洞室”以外),类似的一条隧道也不能重复经
过.
一个著名的洞穴探险家 Byteala 正准备参加这个比赛. Byteala 已经训练了数月而且他已获得了洞穴系统的一套详细资料.
对于每条隧道他都详细计算了从两个方向经过所需要的时间. 经过一个洞室的时间很短可以忽略不记. 现在Byteala 向计算一条符合条件的最优路径.
Input
5000, 3 <= m <= 10000) 分别表示洞室的数目以及连接他们的隧道的数目. 洞室从1 到 n编号.
“前面洞室”的编号为1. 接下来m 行描述了所有的隧道. 每行四个整数a,b,c,d
表示从洞室a到洞室b需要c分钟的时间,而从洞室b到洞室a需要d分钟的时间, 1 <= a,b <= n, a <> b,
1 <= c,d <= 10000. 你可以假设符合要求的路径肯定存在.
Output
Sample Input
1 2 4 3
2 3 4 2
1 3 1 1
Sample Output
HINT
【题解】
http://blog.csdn.net/popoqqq/article/details/46458079
OrzPoPoQQQ
犯的傻逼错:
1、优先队列比较写反
2、A->B却没有B->A
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <queue>
#include <vector>
#define max(a, b) ((a) > (b) ? (a) : (b))
#define min(a, b) ((a) < (b) ? (a) : (b)) inline void read(long long &x)
{
x = ;char ch = getchar(), c = ch;
while(ch < '' || ch > '')c = ch, ch = getchar();
while(ch <= '' && ch >= '')x = x * + ch - '', ch = getchar();
if(c == '-')x = -x;
} const long long MAXN = + ;
const long long MAXM = + ;
const long long INF = 0x3f3f3f3f; struct Edge
{
long long u,v,w,next;
Edge(long long _u, long long _v, long long _w, long long _next){u = _u;v = _v;w = _w;next = _next;}
Edge(){}
}edge[MAXM << ];
long long head[MAXN],cnt; void insert(long long a, long long b, long long c)
{
edge[++cnt] = Edge(a,b,c,head[a]);
head[a] = cnt;
} long long n,m,to1[MAXN],from1[MAXN],node[MAXN],tot; long long A = , B = ; struct Node
{
long long v, d;
Node(long long _v, long long _d){v = _v;d = _d;}
Node(){}
}; struct cmp
{
bool operator()(Node a, Node b)
{
return a.d > b.d;
}
}; std::priority_queue<Node, std::vector<Node>, cmp> q; long long d[MAXN], b[MAXN]; void dijstra(long long s)
{
memset(b, , sizeof(b));
memset(d, 0x3f, sizeof(d));
while(q.size())q.pop();
d[s] = ;
q.push(Node(s, ));
Node now;
while(q.size())
{
now = q.top(), q.pop();
if(now.d != d[now.v] || b[now.v])continue;
b[now.v] = ;
for(register long long pos = head[now.v];pos;pos = edge[pos].next)
{
long long v = edge[pos].v;
if(v > && v != A && v != B)continue;
if(b[v])continue;
if(d[now.v] + edge[pos].w < d[v])
{
d[v] = d[now.v] + edge[pos].w;
q.push(Node(v, d[v]));
}
}
}
} long long ans = INF; int main()
{
read(n);read(m);
register long long tmp1, tmp2, tmp3, tmp4;
for(register long long i = ;i <= m;++ i)
{
read(tmp1), read(tmp2), read(tmp3), read(tmp4);
if(tmp1 == )
{
node[++tot] = tmp2;
to1[tot] = tmp4;
from1[tot] = tmp3;
continue;
}
else if(tmp2 == )
{
node[++tot] = tmp1;
to1[tot] = tmp3;
from1[tot] = tmp4;
continue;
}
insert(tmp1, tmp2, tmp3);
insert(tmp2, tmp1, tmp4);
}
long long M = ;
while(( << M) <= n) ++ M;
-- M;
for(register long long i = ;i <= M;++ i)
{
for(register long long j = ;j <= tot;++ j)
{
if((node[j] >> i) & )
insert(A, node[j], from1[j]);
else
insert(node[j], B, to1[j]);
}
dijstra(A);
ans = min(ans, d[B]);
A = B + ;
B = B + ;
for(register long long j = ;j <= tot;++ j)
{
if((node[j] >> i) & )
insert(node[j], A, to1[j]);
else
insert(B, node[j], from1[j]);
}
dijstra(B);
ans = min(ans, d[A]);
A = B + ;
B = B + ;
}
printf("%d", ans);
return ;
}
BZOJ2069
BZOJ2069: [POI2004]ZAW的更多相关文章
- 2069: [POI2004]ZAW
2069: [POI2004]ZAW 链接 题意: 给定一张带权图(边是双向的,但不同方向长度不同).求从1出发,至少经过除1外的一个点,再回到1的最短路.点和边不能重复经过. n≤5000,m≤10 ...
- BZOJ 2069: [POI2004]ZAW(Dijkstra + 二进制拆分)
题意 给定一个有 \(N\) 个点 \(M\) 条边的无向图, 每条无向边 最多只能经过一次 . 对于边 \((u, v)\) , 从 \(u\) 到 \(v\) 的代价为 \(a\) , 从 \(v ...
- 【刷题】BZOJ 2069 [POI2004]ZAW
Description 在Byte山的山脚下有一个洞穴入口. 这个洞穴由复杂的洞室经过隧道连接构成. 洞穴的入口是一条笔直通向"前面洞口"的道路. 隧道互相都不交叉(他们只在洞室相 ...
- BZOJ.2069.[POI2004]ZAW(最短路Dijkstra 按位划分)
题目链接 \(Description\) 给定一张带权图(边是双向的,但不同方向长度不同).求从1出发,至少经过除1外的一个点,再回到1的最短路.点和边不能重复经过. \(n\leq5000,m\le ...
- bzoj 2096 [POI2004]ZAW——二进制枚举
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2069 可以把直接相连的点分成 从1点出的一部分 和 走向1点的一部分.多起点最短路就和 ...
- BZOJ 2069 POI2004 ZAW 堆优化Dijkstra
题目大意:给定一张无向图.每条边从两个方向走各有一个权值,求从点1往出走至少一步之后回到点1且不经过一条边多次的最短路 显然我们须要从点1出发走到某个和点1相邻的点上,然后沿最短路走到还有一个和点1相 ...
- 【刷题】BZOJ 2407 探险
Description 探险家小T好高兴!X国要举办一次溶洞探险比赛,获奖者将得到丰厚奖品哦!小T虽然对奖品不感兴趣,但是这个大振名声的机会当然不能错过! 比赛即将开始,工作人员说明了这次比赛的规则: ...
- 做题记录 To 2019.2.13
2019-01-18 4543: [POI2014]Hotel加强版:长链剖分+树形dp. 3653: 谈笑风生:dfs序+主席树. POJ 3678 Katu Puzzle:2-sat问题,给n个变 ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
随机推荐
- iPhone开发关于UDID和UUID的一些理解
一.UDID(Unique Device Identifier) UDID是Unique Device Identifier的缩写,中文意思是设备唯一标识. 在很多需要限制一台设备一个账号的应用中 ...
- java生成excel报表文件
此次简单的操作将数据从数据库导出生成excel报表以及将excel数据导入数据库 首先建立数据库的连接池: package jdbc; import java.io.FileInputStream; ...
- 深入理解JVM之类加载
---title: [学习]深入理解JVM之类加载.mddate: 2019-10-20 22:20:06tags: JVM 类加载--- Java类的加载,连接,初始化都是在程序运行期间执行的 ## ...
- [Cqoi2015] 编号 【逆向思维,暴力枚举】
Online Judge:Luogu-P4222 Label:逆向思维,暴力枚举 题目描述 你需要给一批商品编号,其中每个编号都是一个7位16进制数(由0~9, a-f组成).为了防止在人工处理时不小 ...
- Python中的urlparse、urllib抓取和解析网页(一)
对搜索引擎.文件索引.文档转换.数据检索.站点备份或迁移等应用程序来说,经常用到对网页(即HTML文件)的解析处理.事实上,通过Python 语言提供的各种模块,我们无需借助Web服务器或者Web浏览 ...
- css3的3D变形
一.坐标系 1.是我们熟悉的右手坐标系:伸出右手,让拇指和食指成L形,大拇指向为右,食指向上,中指指向前方,这样,拇指.食指.中指的指向分别是X.Y.Z轴的正方向. 2.是我们CSS3中的3D坐标:伸 ...
- 洛谷P3749 [六省联考2017]寿司餐厅
传送门 题解 这几道都是上周llj讲的题,题解也写得十分好了,所以直接贴了几个链接和代码. //Achen #include<algorithm> #include<iostream ...
- 深入浅出 Java Concurrency (7): 锁机制 part 2 AQS[转]
在理解J.U.C原理以及锁机制之前,我们来介绍J.U.C框架最核心也是最复杂的一个基础类:java.util.concurrent.locks.AbstractQueuedSynchronizer. ...
- JEECMS的几个细节
最近想自己写一些标签,看了一下JEECMS,感觉有些标签还是很值得学习的. 1.图片新闻:可以实现类似于flash切换图片的那种效果 效果: 代码: [@cms.ArtiList chnlId='' ...
- 【DM642学习笔记二】dsp基础实验:发光二级管的显示 led.c
1,OSDFPGA配置一个专用的8位寄存器控制指示灯亮灭,访问地址为90080017h,由电路图可知低电平点亮. 2,程序运行时,可直接editmemory.即修改90080017h地址的值(可在Ed ...