P2763: [JLOI2011]飞行路线
然而WA了呀,这道分层图,也是不明白为什么WA了=-=
- const maxe=; maxn=; points=;
- type
- node=record
- f,t,l:longint;
- end;
- var n,m,k,i,j,u,v,x,s,t,num:longint;
- b:array[..maxe] of node;
- ans:int64;
- f:array[..] of longint;
- p:array[..points] of boolean;
- head:array[..points] of longint;
- d:array[..points] of int64;
- procedure insert(u,v,x:longint);
- begin
- inc(num);
- b[num].f:=head[u];
- b[num].t:=v;
- b[num].l:=x;
- head[u]:=num;
- end;
- procedure spfa;
- var now,nowe,l,r,v:longint;
- begin
- for l:= to points do d[l]:=maxn;
- fillchar(p,sizeof(p),true);
- l:=; r:=; f[]:=s; d[s]:=; p[s]:=false; ans:=maxn; //writeln(ans);
- while l<=r do
- begin
- now:=f[l];
- nowe:=head[now];
- while nowe<> do
- begin
- v:=b[nowe].t;
- if d[now]+b[nowe].l<d[v] then
- begin
- d[v]:=d[now]+b[nowe].l;
- if p[v] then
- begin
- p[v]:=false;
- inc(r);
- f[r]:=v;
- end;
- //if ((v mod k)=t) and (d[v]<ans) then ans:=d[v];
- end;
- nowe:=b[nowe].f;
- end;
- inc(l);
- p[now]:=true;
- end;
- for l:= to k do
- if ans>d[l*n+t] then ans:=d[l*n+t];
- end;
- begin
- readln(n,m,k);
- readln(s,t);
- inc(s); inc(t);
- for i:= to m do
- begin
- readln(u,v,x);
- inc(u); inc(v);
- for j:= to k do
- begin
- insert(u+j*n,v+j*n,x);
- insert(v+j*n,u+j*n,x);
- if j<>k then
- begin
- insert(u+j*n,v+(j+)*n,);
- insert(v+j*n,u+(j+)*n,);
- end;
- end;
- end;
- spfa;
- if ans=maxn then writeln()
- else writeln(ans);
- end.
暂且先不管为什么WA吧,首先这是个分层图原图既然是一层的。我们把它拆成k+1层。每一条边既能连本层,也能连到下一层。然后直接裸上Dijikstra即可,而spfa大概也是可以的吧。
而这是正解
- #include <queue>
- #include <cstdio>
- #include <cstring>
- #include <iostream>
- #include <algorithm>
- #define N 1200100
- using namespace std;
- int n,m,k;
- int st,ed,cnt;
- int head[N];
- int dis[N];
- int v[N];
- struct node
- {
- int from,to,val,next;
- }edge[N<<];
- struct element
- {
- int val,no;
- };
- bool operator < (element a,element b)
- {
- if(a.val==b.val)return a.no<b.no;
- return a.val>b.val;
- }
- priority_queue<element>q;
- void dijikstra(int s,int e)
- {
- memset(dis,0x3f,sizeof(dis));
- element fir;
- fir.val=,fir.no=s;
- dis[s]=;
- q.push(fir);
- while(!q.empty())
- {
- element u=q.top();
- q.pop();
- if(v[u.no])continue;
- v[u.no]=;
- for(int i=head[u.no];i!=-;i=edge[i].next)
- {
- int to=edge[i].to;
- if(dis[u.no]+edge[i].val<dis[to])
- {
- dis[to]=dis[u.no]+edge[i].val;
- element pus;
- pus.no=to,pus.val=dis[to];
- q.push(pus);
- }
- }
- }
- int ans=0x3f3f3f3f;
- for(int i=;i<=k;i++)
- {
- ans=min(ans,dis[e+i*n]);
- }
- printf("%d\n",ans);
- }
- void init()
- {
- memset(head,-,sizeof(head));
- cnt=;
- }
- void edgeadd(int from,int to,int val)
- {
- edge[cnt].from=from;
- edge[cnt].to=to;
- edge[cnt].val=val;
- edge[cnt].next=head[from];
- head[from]=cnt++;
- }
- int main()
- {
- init();
- scanf("%d%d%d",&n,&m,&k);
- scanf("%d%d",&st,&ed);
- st++,ed++;
- for(int i=;i<=m;i++)
- {
- int x,y,z;
- scanf("%d%d%d",&x,&y,&z);
- x++,y++;
- for(int i=;i<=k;i++)
- {
- edgeadd(x+i*n,y+i*n,z);
- edgeadd(y+i*n,x+i*n,z);
- if(i!=k)
- {
- edgeadd(x+i*n,y+(i+)*n,);
- edgeadd(y+i*n,x+(i+)*n,);
- }
- }
- }
- dijikstra(st,ed);
- }
P2763: [JLOI2011]飞行路线的更多相关文章
- BZOJ2763[JLOI2011]飞行路线 [分层图最短路]
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2523 Solved: 946[Submit][Statu ...
- 分层图+最短路算法 BZOJ 2763: [JLOI2011]飞行路线
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MB Description Alice和Bob现在要乘飞机旅行,他们选择了一家相 ...
- BZOJ 2763: [JLOI2011]飞行路线 最短路
2763: [JLOI2011]飞行路线 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...
- poj 2763: [JLOI2011]飞行路线(spfa分层图最短路)
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MB Submit: 2156 Solved: 818 [Submit][Statu ...
- Bzoj 2763: [JLOI2011]飞行路线 dijkstra,堆,最短路,分层图
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1728 Solved: 649[Submit][Statu ...
- Bzoj 2763: [JLOI2011]飞行路线 拆点,分层图,最短路,SPFA
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1694 Solved: 635[Submit][Statu ...
- [JLOI2011]飞行路线 不同的算法,不同的悲伤
题目 :BZOJ2763 洛谷P4568 [JLOI2011]飞行路线 一道最短路的题目,想想写个题解也不错(好久没写题解了_(:з」∠)_) 然后这道题中心思路是dijikstra处理最短路,所以没 ...
- 洛谷 P4568 [JLOI2011]飞行路线 解题报告
P4568 [JLOI2011]飞行路线 题目描述 Alice和Bob现在要乘飞机旅行,他们选择了一家相对便宜的航空公司.该航空公司一共在\(n\)个城市设有业务,设这些城市分别标记为0到\(n−1\ ...
- bzoj千题计划226:bzoj2763: [JLOI2011]飞行路线
http://www.lydsy.com/JudgeOnline/problem.php?id=2763 这也算分层图最短路? dp[i][j]到城市i,还剩k次免费次数的最短路 #include&l ...
随机推荐
- dedecms手机站要同步pc站的图片
首先在dede目录下面找到 /include/extend.func.php 文件 //添加自定义函数 function replaceurl($newurl){ $newurl=str_repl ...
- .NET平台下,关于数据持久层框架
在.NET平台下,关于数据持久层框架非常多,本文主要对如下几种做简要的介绍并推荐一些学习的资源: 1.NHibernate 2.NBear 3.Castle ActiveRecord 4.iBATIS ...
- 错误处理php
一 HP关闭脚本错误提示的方法: 打开PHP安装目录下的php.ini文件 找到display_errors = On 修改为 display_errors = off 注意:如果你已经把PHP.in ...
- 信息图形(Infographic)
信息图形(Infographic),又称为信息图,是指数据.信息或知识的可视化表现形式.信息图形主要应用于必须要有一个清楚准确的解释或表达甚为复杂且大量的信息,例如在各式各样的文件档案上.各个地图及标 ...
- linux网络bond技术
http://blog.chinaunix.net/uid-20799583-id-3117665.html1.创建bond0配置文件vi /etc/sysconfig/network-scripts ...
- Win2008R2PHP5.4环境加载Zend模块
1.需要2个文件 Zend Optimizer和Zend Guard Loade s 下载Zend Guard Loader包.(官方地址:http://www.zend.com/en/product ...
- C#实现图书馆程序导入ISO-2709格式(MARC)功能
1.导入 /// <summary> /// 导入ISO2709 /// </summary> /// <param name="sender"> ...
- C#中判断文件夹中存在某个txt文本
strFileName="D:\\strarray.txt"; if (File.Exists(strFileName))//判断文件是否存在 { }
- url 编码(percentcode 百分号编码)
http://www.imkevinyang.com/2009/08/%E8%AF%A6%E8%A7%A3javascript%E4%B8%AD%E7%9A%84url%E7%BC%96%E8%A7% ...
- Java实现九九乘法表的输出
九九乘法表一般为三角形,每个数分别和从1到自身的数相乘然后把结果列出来,即要用到两层循环,外层是从1到9for(i=1;i<=9;i++),内层是当前数和从1到自身相乘for(j=1;j< ...