【POJ2449】Remmarguts' Date (A* k短路)
来源:互联网 发布:农村网络服务站 编辑:程序博客网 时间:2024/05/20 06:40
题目链接:http://poj.org/problem?id=2449
题解:
A*求k短路模板题…
反向SPFA,dis数组为估价函数,当目标点的更新次数达到k时,就求出了广义上的k短路
//by sdfzchy#include<cstdio>#include<cstring>#include<iostream>#include<algorithm>#include<queue>using namespace std;typedef long long LL;const int N=1010;const int M=100010;int n,m,ecnt,head[N],hhead[N],s,t,k;struct E{ int to,dis,nxt;}e[M],ee[M];void add_edge(int u,int v,int w){ ++ecnt; e[ecnt]=(E){v,w,head[u]}; head[u]=ecnt; ee[ecnt]=(E){u,w,hhead[v]}; hhead[v]=ecnt;}int dis[N];bool vis[N];void spfa(){ queue<int> q; memset(dis,0x7f,sizeof(dis)); dis[t]=0,vis[t]=1; q.push(t); while(!q.empty()) { int u=q.front(); q.pop(); vis[u]=0; for(int i=hhead[u];i;i=ee[i].nxt) { int v=ee[i].to; if(dis[u]+ee[i].dis<dis[v]) { dis[v]=dis[u]+ee[i].dis; if(!vis[v]) vis[v]=1,q.push(v); } } }}struct A{ int point,h,g; bool operator <(const A& x)const { return h+g>x.h+x.g; }};int A_star(){ int cnt=0; priority_queue<A>Q; if(s==t) k++; Q.push((A){s,dis[s],0}); while(!Q.empty()) { A u=Q.top(); Q.pop(); if(u.point==t) if(++cnt==k) return u.g; for(int i=head[u.point];i;i=e[i].nxt) Q.push((A){e[i].to,dis[e[i].to],u.g+e[i].dis}); } return -1;}int main(){ scanf("%d%d",&n,&m); for(int i=1,u,v,w;i<=m;i++) { scanf("%d%d%d",&u,&v,&w); add_edge(u,v,w); } scanf("%d%d%d",&s,&t,&k); spfa(); printf("%d\n",A_star()); return 0;}
阅读全文
0 0
- 【POJ2449】Remmarguts' Date (A* k短路)
- 【A* + 第K短路】 poj2449 Remmarguts' Date
- poj2449 Remmarguts' Date 第K短路 A*
- poj2449 Remmarguts' Date A*K短路
- Remmarguts' Date poj2449 k短路 A*
- 【A*求K短路】POJ2449 Remmarguts' Date
- POJ2449 Remmarguts' Date A*搜索K短路
- poj2449 Remmarguts' Date --- k短路模板(SPFA+A*)
- poj2449 Remmarguts' Date(K短路:A*算法)
- 【Poj2449】Remmarguts' Date-k短路(A*解法)
- poj2449 Remmarguts' Date-k短路+A*(待解决)
- POJ2449-Remmarguts' Date(K短路)
- POJ2449-Remmarguts' Date(k短路)
- POJ2449 Remmarguts' Date 【k短路】
- [POJ2449] Remmarguts' Date(裸k短路)(A*搜索)
- poj2449 Remmarguts' Date,第K短路
- POJ2449 Remmarguts' Date 第K短路
- poj2449 Remmarguts' Date A*
- Maven环境配置及引用
- Eclipse搭建Maven的环境变量
- 笔记本Windows10+Ubuntu双系统UEFI安装教程
- ElasticSearch-深入理解系列7-分布式增删查改
- 网络攻防技术与实践笔记-TCP/IP网络协议攻击
- 【POJ2449】Remmarguts' Date (A* k短路)
- "could not create the java virtual machine"启动eclipse报错
- 原来这就是 ’面向对象‘, ‘编程’。。
- [转]hadoop,spark,storm,pig,hive,mahout等到底有什么区别和联系?
- 在windows上传一个新的项目到GitHub上
- 扩增子统计绘图1箱线图:Alpha多样性
- Building Serverless Architectures pdf
- ElasticSearch-深入理解系列8-高级查询
- 树莓派之SPI编程