bzoj2763
首先是稀疏图,不难想到dij+heap
观察题目可以知道,0<=k<=10;
所以比较裸的想法就是,d[i,j]表示已经免费了i条线路后到达j的最短路
容易得到
d[i,j]:=min(d[i,j],d[i-1,k]);
d[i,j]:=min(d[i,j],d[i,k]+w[k,j]);
然后在做dij在选择中间点的时候,我们穷举一下免费的线路数就可以了;
然后就要维护10个堆……
语言表述有点渣,具体还是看程序吧
const inf=;
type point=record
num,dis:longint;
end;
node=record
next,cost,point:longint;
end; var edge:array[..] of node;
heap:array[..,..] of point;
d,where:array[..,..] of longint;
h:array[..] of longint;
p:array[..] of longint;
len,x,y,z,i,j,n,m,u,k,s,t:longint; procedure swap(var a,b:point);
var c:point;
begin
c:=a;
a:=b;
b:=c;
end; function min(a,b:longint):longint;
begin
if a>b then exit(b) else exit(a);
end; procedure add(x,y,z:longint);
begin
inc(len);
edge[len].point:=y;
edge[len].cost:=z;
edge[len].next:=p[x];
p[x]:=len;
end; procedure sift(p,i:longint);
var j,x,y:longint;
begin
j:=i shl ;
while j<=h[p] do
begin
if (j+<=h[p]) and (heap[p,j].dis>heap[p,j+].dis) then inc(j);
if heap[p,i].dis>heap[p,j].dis then
begin
x:=heap[p,i].num;
y:=heap[p,j].num;
where[p,x]:=j;
where[p,y]:=i;
swap(heap[p,i],heap[p,j]);
i:=j;
j:=i shl ;
end
else break;
end;
end; procedure up(p,i:longint);
var j,x,y:longint;
begin
j:=i shr ;
while j> do
begin
if heap[p,i].dis<heap[p,j].dis then
begin
x:=heap[p,i].num;
y:=heap[p,j].num;
where[p,x]:=j;
where[p,y]:=i;
swap(heap[p,i],heap[p,j]);
i:=j;
j:=j shr ;
end
else break;
end;
end; begin
len:=-;
fillchar(p,sizeof(p),);
readln(n,m,k);
readln(s,t);
inc(s); //点序号都+,习惯一点
inc(t);
for i:= to m do
begin
readln(x,y,z);
inc(x);
inc(y);
add(x,y,z);
add(y,x,z);
end;
for i:= to n do
if i<>s then
begin
for j:= to k do
d[j,i]:=inf;
end
else
for j:= to k do
d[j,i]:=;
for i:= to k do
begin
for j:= to n do
begin
heap[i,j].num:=j;
heap[i,j].dis:=d[i,j];
where[i,j]:=j;
end;
h[i]:=n;
end;
for i:= to k do
up(i,s); //起点不一定是0,要初始化堆,一开始这里被坑翻了
for u:= to n do
begin
for j:=k downto do
begin
x:=heap[j,].num;
y:=heap[j,h[j]].num;
if (h[j]=) or (d[j,x]=inf) then continue;
where[j,y]:=; //dij+heap比较重要的细节
swap(heap[j,],heap[j,h[j]]);
dec(h[j]);
sift(j,); //出堆,调整堆
i:=p[x];
while i<>- do
begin
y:=edge[i].point;
if (j<>k) and (d[j+,y]>d[j,x]) then //两种情况
begin
d[j+,y]:=d[j,x];
heap[j+,where[j+,y]].dis:=d[j+,y];
up(j+,where[j+,y]);
end;
if (d[j,y]>d[j,x]+edge[i].cost) then
begin
d[j,y]:=d[j,x]+edge[i].cost;
heap[j,where[j,y]].dis:=d[j,y];
up(j,where[j,y]);
end;
i:=edge[i].next;
end;
end;
end;
writeln(d[k,t]); //肯定尽可能免费好啊
end.
bzoj2763的更多相关文章
- BZOJ2763[JLOI2011]飞行路线 [分层图最短路]
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2523 Solved: 946[Submit][Statu ...
- 【BZOJ2763】飞行路线(最短路)
[BZOJ2763]飞行路线(最短路) 题面 BZOJ Description Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标 ...
- BZOJ2763 JLOI2011 飞行路线 【最短路+DP】
BZOJ2763 JLOI2011 飞行路线 Description Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为0到n ...
- 【bzoj2763】[JLOI2011]飞行路线 (分层图最短路)(优先队列dij)
[bzoj2763][JLOI2011]飞行路线 2014年3月25日1,7260 Description Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城 ...
- 分层图最短路【bzoj2763】: [JLOI2011]飞行路线
bzoj2763: [JLOI2011]飞行路线 Description Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为0 ...
- BZOJ2763 [JLOI2011]飞行路线(SPFA + DP)
题目 Source http://www.lydsy.com/JudgeOnline/problem.php?id=2763 Description Alice和Bob现在要乘飞机旅行,他们选择了一家 ...
- Bzoj2763 [JLOI2011]飞行路线
Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2651 Solved: 1004 Description Alice和Bob现在要乘飞机旅行,他们选 ...
- bzoj2763: [JLOI2011]飞行路线 分层图+dij+heap
分析:d[i][j]代表从起点到点j,用了i次免费机会,那就可以最短路求解 #include <stdio.h> #include <iostream> #include &l ...
- [luogu4568][bzoj2763][JLOI2011]飞行路线
题目描述 Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在n个城市设有业务,设这些城市分别标记为00到n-1,一共有m种航线,每种航线连接两个城市,并且航线有一定 ...
随机推荐
- 用 CSS 隐藏页面元素的 5 种方法
原文链接:用 CSS 隐藏页面元素的 5 种方法,转载请注明来源! 用 CSS 隐藏页面元素有许多种方法.你可以将 opacity 设为 0.将 visibility 设为 hidden.将 disp ...
- windows2003可用gt630显卡驱动
http://file2.mydrivers.com/display/301.42-desktop-winxp-32-international-whql.exe 驱动精灵自动下载的不好用,这个版本可 ...
- java培训(5-8节课)
面向对象: 1.利用面向对象的语法,实现代码的拆分(数据存储:对象的传值). 2.利用面向对象的语法,实现程序的结构处理(继承,多态,接口,抽象类). 3.用面向对象的编程方法,理解实现程序开发的框架 ...
- 清橙OJ 1082 查找第K小元素 -- 快速排序
题目地址:http://oj.tsinsen.com/A1082 问题描述 给定一个大小为n的数组s和一个整数K,请找出数组中的第K小元素. 这是一个补充程序的试题,你需要完成一个函数: int fi ...
- 24种设计模式--中介者模式【Mediator Pattern】
各位好,大家都是来自五湖四海,都要生存,于是都找了个靠山——公司,给你发薪水的地方,那公司就要想尽办法盈利赚钱,盈利方法则不尽相同,但是作为公司都有相同三个环节:采购.销售和库存,这个怎么说呢?比如一 ...
- Java知识总结--JDBC&XML
1说说jdbc连接数据库的步骤 1.注册驱动 2.获得连接 3.执行sql语句 4.获得结果集,进行结果集的处理 5.关闭结果集 6.关闭连接,释放资源 2 statement 和preparedst ...
- nginx中的try_files指令解释
try_files 指令的官方介绍比较让人摸不着头脑,经网上一番总结查看,try_files最核心的功能是可以替代rewrite. try_files 语法: try_files file . ...
- Android开发第2篇 - Git插件安装
一.Eclipse上安装GIT插件EGit Eclipse的版本eclipse-java-helios-SR2-win32.zip(在Eclipse3.3版本找不到对应的 EGit插件,无法安装) E ...
- 【Ubuntu12.04】安装搜狗输入法
我的系统版本是Ubuntu12.04 32位 卸载Ibus输入法 sudo apt-get remove ibus 注意: 安装ibus的命令是 sudo apt-get install fcitx ...
- ORA-24010 SMG-3000
参考:http://t.askmaclean.com/thread-528-1-1.html 运行脚本的时候一定要清楚脚本做了什么操作,注意看清脚本的报错. conn / as sysdba@?/rd ...