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 ...
随机推荐
- jvm-java内存模型与锁优化
java内存模型与锁优化 参考: https://blog.csdn.net/xiaoxiaoyusheng2012/article/details/53143355 https://blog.csd ...
- LeetCode——Longest Consecutive Sequence
LeetCode--Longest Consecutive Sequence Question Given an unsorted array of integers, find the length ...
- Makefile文件应用——huge项目
提高复用性 在build目录下,保存公用部分make.rule (1)绝对路径 用ROOT变量保存项目根目录 (2)增加控制变量 EXE/LIB/ (3)头文件查找目录 gcc 的-I(i的大写)选项 ...
- 解决org.apache.hadoop.io.nativeio.NativeIO$Windows.access0(Ljava/lang/String;I)Z
这个问题来的有点莫名奇妙,之前我的hadoop运行一直是正常的,某一天开始运行Mapreduce就报这个错. 试过很多种方法都没有用,比如 1.path环境变量2.Hadoop bin目录下hadoo ...
- Treflection03_getFields_getField
1. package reflectionZ; import java.lang.reflect.Constructor; import java.lang.reflect.Field; public ...
- Linux 设备驱动之 UIO 机制
一个设备驱动的主要任务有两个: 1. 存取设备的内存 2. 处理设备产生的中断 对于第一个任务.UIO 核心实现了mmap()能够处理物理内存(physical memory),逻辑内存(logica ...
- css滚动相关问题记录
1) 关于滑动加速优化,可以通过css进行处理 例如,html如下: <div class="content-dialog"> <h1>活动规则</h ...
- mysql数据库(一):建表与新增数据
一. 学习目标 理解什么是数据库,什么是表 怎样创建数据库和表(create) 怎样往表里插入数据(insert) 怎样修改表里的数据(update) 怎样删除数据库,表以及数据(delete) 二. ...
- quartz简单应用
pom.xml<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3 ...
- python----异常处理(二)
格式如下: try: pass except Exception as e:#如果上面出错,执行下面代码 pass else:#try如果没出错执行此下面代码 pass fin ...