bzoj 2763 [JLOI2011]飞行路线——分层图
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=2763
分层图两种方法的练习。
1.把图分成k+1层,本层去上面一层的边免费。但空间时间都不算优秀。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#define ll long long
using namespace std;
const int N=1e4+,M=5e4+,K=;
int n,m,k,head[N*K],xnt,s,t;
ll dis[N*K],ans=0x7fffffff;
bool vis[N*K];
struct Edge{
int next,to,w;
Edge(int n=,int t=,int w=):next(n),to(t),w(w) {}
}edge[M*K<<];
void add(int x,int y,int z)
{
for(int fx=;fx<=k*n;fx+=n)
{
edge[++xnt]=Edge(head[x+fx],y+fx,z);head[x+fx]=xnt;
if(fx<k*n)
edge[++xnt]=Edge(head[x+fx],y+fx+n,),head[x+fx]=xnt;
}
}
void dj()
{
memset(dis,,sizeof dis);dis[s]=;
priority_queue<pair<ll,int>,vector<pair<ll,int> >,greater<pair<ll,int> > > q;
q.push(make_pair(,s));
while(q.size())
{
int u=q.top().second;q.pop();
while(vis[u]&&q.size())u=q.top().second,q.pop();
if(vis[u])break;vis[u]=;
for(int i=head[u],v;i;i=edge[i].next)
if(dis[v=edge[i].to]>dis[u]+edge[i].w)
{
dis[v]=dis[u]+edge[i].w;q.push(make_pair(dis[v],v));
}
}
}
int main()
{
scanf("%d%d%d%d%d",&n,&m,&k,&s,&t);
int x,y,z;
for(int i=;i<=m;i++)
{
scanf("%d%d%d",&x,&y,&z);
add(x,y,z);add(y,x,z);
}
dj();
for(int fx=;fx<=k*n;fx+=n)ans=min(ans,dis[t+fx]);
printf("%lld",ans);
return ;
}
2.设计dp状态,套在最短路上。就不用建边,从而省空间。
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#define ll long long
using namespace std;
const int N=1e4+,M=5e4+,K=;
int n,m,k,s,t,head[N],xnt;
ll ans=0x7fffffff,dp[N][K];
bool vis[N][K];
struct Edge{
int next,to,w;
Edge(int n=,int t=,int w=):next(n),to(t),w(w) {}
}edge[M<<];
void add(int x,int y,int z)
{
edge[++xnt]=Edge(head[x],y,z);head[x]=xnt;
edge[++xnt]=Edge(head[y],x,z);head[y]=xnt;
}
void spfa()
{
memset(dp,,sizeof dp);dp[s][]=;
queue<pair<int,int> > q;q.push(make_pair(s,));vis[s][]=;
while(q.size())
{
int u=q.front().first,d=q.front().second;q.pop();
vis[u][d]=;
for(int i=head[u],v;i;i=edge[i].next)
{
if(dp[v=edge[i].to][d]>dp[u][d]+edge[i].w)
{
dp[v][d]=dp[u][d]+edge[i].w;
if(!vis[v][d])vis[v][d]=,q.push(make_pair(v,d));
}
if(d<k&&dp[v][d+]>dp[u][d])
{
dp[v][d+]=dp[u][d];
if(!vis[v][d+])vis[v][d+]=,q.push(make_pair(v,d+));
}
}
}
}
int main()
{
scanf("%d%d%d%d%d",&n,&m,&k,&s,&t);
int x,y,z;
for(int i=;i<=m;i++)
{
scanf("%d%d%d",&x,&y,&z);add(x,y,z);
}
spfa();
for(int i=;i<=k;i++)ans=min(ans,dp[t][i]);
printf("%lld",ans);
return ;
}
上面的代码巨慢!用dj的话可以及时推出,所以会非常快!
#include<iostream>
#include<cstdio>
#include<cstring>
#include<queue>
#define ll long long
using namespace std;
const int N=1e4+,M=5e4+,K=;
int n,m,k,s,t,head[N],xnt;
ll ans=0x7fffffff,dp[N][K];
bool vis[N][K];
struct Edge{
int next,to,w;
Edge(int n=,int t=,int w=):next(n),to(t),w(w) {}
}edge[M<<];
struct Node{
ll dis;int v,c;
Node(ll d,int a,int b):dis(d),v(a),c(b) {}
bool operator<(const Node k)const
{
return dis>k.dis;
}
};
void add(int x,int y,int z)
{
edge[++xnt]=Edge(head[x],y,z);head[x]=xnt;
edge[++xnt]=Edge(head[y],x,z);head[y]=xnt;
}
void dj()
{
memset(dp,,sizeof dp);dp[s][]=;
priority_queue<Node> q;
q.push(Node(,s,));
while(q.size())
{
ll x=q.top().dis,u=q.top().v,d=q.top().c;q.pop();
while(vis[u][d]&&q.size())x=q.top().dis,u=q.top().v,d=q.top().c,q.pop();
if(vis[u][d])break;vis[u][d]=;
if(u==t){ans=x;return;}
for(int i=head[u],v;i;i=edge[i].next)
{
if(dp[v=edge[i].to][d]>x+edge[i].w)
{
dp[v][d]=x+edge[i].w;q.push(Node(dp[v][d],v,d));
}
if(d<k&&dp[v][d+]>x)
{
dp[v][d+]=x;q.push(Node(dp[v][d+],v,d+));
}
}
}
}
int main()
{
scanf("%d%d%d%d%d",&n,&m,&k,&s,&t);
int x,y,z;
for(int i=;i<=m;i++)
{
scanf("%d%d%d",&x,&y,&z);add(x,y,z);
}
dj();
printf("%lld",ans);
return ;
}
bzoj 2763 [JLOI2011]飞行路线——分层图的更多相关文章
- bzoj 2763: [JLOI2011]飞行路线 -- 分层图最短路
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MB Description Alice和Bob现在要乘飞机旅行,他们选择了一家相 ...
- bzoj 2763: [JLOI2011]飞行路线 分层图
题目链接 n个点m条路, 每条路有权值, 给出起点和终点, 求一条路使得权值最小.可以使路过的路中, k条路的权值忽略. 其实就是多一维, 具体看代码 #include<bits/stdc++ ...
- Bzoj 2763: [JLOI2011]飞行路线 拆点,分层图,最短路,SPFA
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1694 Solved: 635[Submit][Statu ...
- 分层图+最短路算法 BZOJ 2763: [JLOI2011]飞行路线
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MB Description Alice和Bob现在要乘飞机旅行,他们选择了一家相 ...
- Bzoj 2763: [JLOI2011]飞行路线 dijkstra,堆,最短路,分层图
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1728 Solved: 649[Submit][Statu ...
- BZOJ 2763: [JLOI2011]飞行路线 【分层图模板】
任意门:https://www.lydsy.com/JudgeOnline/problem.php?id=2763 2763: [JLOI2011]飞行路线 Time Limit: 10 Sec M ...
- bzoj2763: [JLOI2011]飞行路线(分层图spfa)
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3234 Solved: 1235[Submit][Stat ...
- BZOJ2763[JLOI2011]飞行路线 [分层图最短路]
2763: [JLOI2011]飞行路线 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 2523 Solved: 946[Submit][Statu ...
- BZOJ 2763: [JLOI2011]飞行路线 最短路
2763: [JLOI2011]飞行路线 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...
随机推荐
- Spring AOP(4)
- 网易编程题——Fibonacci数列
题目描述 Fibonacci数列是这样定义的: F[0] = 0 F[1] = 1 for each i ≥ 2: F[i] = F[i-1] + F[i-2] 因此,Fibonacci数列就形如:0 ...
- LeetCode——Keyboard Row
LeetCode--Keyboard Row Question Given a List of words, return the words that can be typed using lett ...
- windchill相关功能操作
1.创建产品 2.创建文件夹 3.创建文档 4.创建用户账号 5.创建组 6.创建更改请求 7.创建部件新视图版本 8.创建可重用属性和全局枚举 9.在组织内分配上下文 ...
- eclipse——添加Tomcat7.0服务器
首先要安装好Tomcat 然后在eclipse中添加Tomcat 步骤如下 详细可参考这篇博客https://blog.csdn.net/u014079773/article/details/5139 ...
- CentOS 5 上使用yum同时安装32位和64位包的解决方法
在centos上使用yum在线安装软件包的时候,有时候会同时安装32位和64位的包.并且在update的时候也会更新双份. 其实让yum只安装64位的包,只要在 /etc/yum.conf 中加个 e ...
- CTCS-2017滚粗记
Day 0: 下午不到四点就来到了宾馆,环境好评,网速能接受,但是你给我搞了个大床房是什么玩意儿啊... 晚上看MasterJH5574大神一直在写题热身(无限崇拜),自己板子没看几眼就丢到一遍去了, ...
- jmeter-JSON Path Assertion(对响应的json数据进行断言)
1,通过plugin manager 安装json pllugins
- GO学习笔记:函数作为值、类型
在Go中函数也是一种变量,我们可以通过type来定义它,它的类型就是所有拥有相同的参数,相同的返回值的一种类型: type typeName func(input1 inputType1 , inpu ...
- 四十三 Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)的mapping映射管理
1.映射(mapping)介绍 映射:创建索引的时候,可以预先定义字段的类型以及相关属性elasticsearch会根据json源数据的基础类型猜测你想要的字段映射,将输入的数据转换成可搜索的索引项, ...