k短路算法
k短路算法
求解k短路用到了A* 算法,A* ( A star )算法,又称启发式搜索算法,与之相对的,dfs与bfs都成为盲目型搜索;即为带有估价函数的优先队列BFS称为A*算法。
该算法的核心思想为设计一个估价函数,估价函数需要满足下面几个准则:
1:设当前状态state到目标状态所需的估计值为\(f(state)\)。
2:在未来的搜索中,实际求出的从当前状态state到目标状态的最小代价为\(g(state)\)。
3:对于任意的\(state\),应该有\(f(state)<=g(state)\)。
之后每次取出“当前代价+未来估价最小的状态,最终更新到目标状态上,就能得到最优解。
A*算法的应用非常广,被广泛应用于最优路径求解和一些策略设计问题中。
首先跑一下Dijkstra或者SPFA反向求一下终点到各个点的最短路,然后A*求出k短路,上代码:
#include<cstdio>
#include<cstring>
#include<queue>
using namespace std;
const int maxn=1e5+10;
const int inf=0x3f3f3f3f;
int head[maxn],head1[maxn],tot,tot1;
int n,m,s,t,k,dis[maxn];
struct Edge{
int nex,to,val;
}edge[maxn],edge1[maxn];
struct node{
int to,f,g; //估价函数和实际代价
friend bool operator <(const node& a,const node& b){
if(a.f==b.f) return a.g>b.g;
return a.f>b.f;
}
}now,temp;
bool vis[maxn];
void add(int from,int to,int val)
{
edge[++tot].to=to;
edge[tot].val=val;
edge[tot].nex=head[from];
head[from]=tot;
}
void add1(int from,int to,int val)
{
edge1[++tot1].to=to;
edge1[tot1].val=val;
edge1[tot1].nex=head1[from];
head1[from]=tot1;
}
queue<int> q;
bool spfa(int s)
{
for(int i=1;i<=n;++i){
dis[i]=inf;
vis[i]=false;
}
vis[s]=1;
dis[s]=0;
while(!q.empty()) q.pop();
q.push(s);
while(!q.empty())
{
int u=q.front();
q.pop();
vis[u] = 0;
for(int i=head1[u];i!=-1;i=edge1[i].nex){
int v=edge1[i].to;
if(dis[v]>dis[u]+edge[i].val){
dis[v]=dis[u]+edge[i].val;
if(vis[v]) continue;
vis[v] = 1;
q.push(v);
}
}
}
return true;
}
priority_queue<node> que;
int A_star()
{
int cnt=0;
while(!que.empty()) que.pop();
if(!spfa(t)||dis[s]==inf) return -1;
if(s==t) ++k; //起点跟终点相同,不能算dis=0这一条
now.to=s;
now.g=0;
now.f=now.g+dis[now.to];
que.push(now);
while(!que.empty()){
now = que.top();
que.pop();
if(now.to==t) cnt++;
if(cnt==k) return now.g;
for(int i=head[now.to];i!=-1;i=edge[i].nex){
temp.to=edge[i].to;
temp.g=now.g+edge[i].val;
temp.f=temp.g+dis[temp.to];
que.push(temp);
}
}
return -1;
}
int main()
{
while(scanf("%d %d",&n,&m)==2)
{
for(int i=1;i<=n;++i){
head[i]=head1[i]=-1;
}
tot=tot1=0;
for(int i=1;i<=m;++i){
int a,b,val;
scanf("%d %d %d",&a,&b,&val);
add(a,b,val);
add1(b,a,val);
}
scanf("%d %d %d",&s,&t,&k);
printf("%d\n",A_star());
}
}
k短路算法的更多相关文章
- 浅谈k短路算法
An Old but Classic Problem 给定一个$n$个点,$m$条边的带正权有向图.给定$s$和$t$,询问$s$到$t$的所有权和为正路径中,第$k$短的长度. Notice 定义两 ...
- POJ 2449 Remmarguts' Date (K短路 A*算法)
题目链接 Description "Good man never makes girls wait or breaks an appointment!" said the mand ...
- A*算法的认识与求第K短路模板
现在来了解A*算法是什么 现在来解决A*求K短路问题 在一个有权图中,从起点到终点最短的路径成为最短路,第2短的路成为次短路,第3短的路成为第3短路,依此类推,第k短的路成为第k短路.那么,第k短路怎 ...
- POJ 2449 Remmarguts' Date ( 第 k 短路 && A*算法 )
题意 : 给出一个有向图.求起点 s 到终点 t 的第 k 短路.不存在则输出 -1 #include<stdio.h> #include<string.h> #include ...
- POJ 2449Remmarguts' Date 第K短路
Remmarguts' Date Time Limit: 4000MS Memory Limit: 65536K Total Submissions: 29625 Accepted: 8034 ...
- POJ--2449--Remmarguts' Date【dijkstra_heap+A*】第K短路
链接:http://poj.org/problem?id=2449 题意:告诉你有n个顶点,m条边.并把这些边的信息告诉你:起点.终点.权值.再告诉你s.t.k.需求出s到t的第k短路,没有则输出-1 ...
- 沈阳网络赛D-Made In Heaven【k短路】【模板】
One day in the jail, F·F invites Jolyne Kujo (JOJO in brief) to play tennis with her. However, Pucci ...
- poj2449(k短路&A_star模板)
题目链接:http://poj.org/problem?id=2449 题意:给出一个有向图,求s到t的第k短路: 思路:k短路模板题,可以用A_star模板过: 单源点最短路径+高级搜索A*;A*算 ...
- 【k短路&A*算法】BZOJ1975: [Sdoi2010]魔法猪学院
Description 找出1~k短路的长度. Solution k短路的求解要用到A*算法 A*算法的启发式函数f(n)=g(n)+h(n) g(n)是状态空间中搜索到n所花的实际代价 h(n) ...
随机推荐
- P & R 11
要做好floorplan需要掌握哪些知识跟技能? 首先熟悉data flow对摆floorplan 有好处,对于减少chip的congestion 是有帮助的,但是也不是必需的,尤其是EDA工具快速发 ...
- 使用Canvas画布的注意事项
1.开始一个路径时要使用beiginPath()方法 ,不然会发生意想不到的事件. 2.图片加载完成后才能按照顺序依次绘图 (巧用onload时间)
- python进阶(十七)正则&json(上)
1. 一个列表中所有的数字都是重复2次,但是有一个数字只重复了一次. 请找出重复一次的数字,不可以使用内置函数. [2,2,1,1,0,4,3,4,3] 方法1:通过字典计数,找到value等于1的k ...
- linux 安装 Jenkins
yum的repo中默认没有Jenkins,需要先将Jenkins存储库添加到yum repos,执行下面的命令: wget -O /etc/yum.repos.d/jenkins.repo https ...
- react组件之间传值方式
1.父向子(通过props传值) 2.父向更深层的子(通过context传值) 3.子向父(通过回调函数传值:在父组件中创建一个函数来接收子组件传过来的参数值,通过父组件将这个函数做为子组件的属性传递 ...
- redis (一) --- 基本使用
概述 redis是基于key-value 我们所说的数据类型实际是 key-value 中的 value .文章主要介绍的是redis 几个重要的数据类型的使用. 简单使用 //keys patter ...
- 【CSS选择器】
" 目录 一.介绍 二.语法 三.引入方式 1. 行内样式 2. 嵌入式 3. 外部样式 四.选择器 1. 基本选择器 2. 组合选择器 3. 属性选择器 4. 不常用选择器 5. 分组和嵌 ...
- LA 3708 墓地雕塑(模拟)
题目链接:https://vjudge.net/problem/UVALive-3708 这道题的思路也是比较难想. 首先根据上一题(Uva 11300)可知,要想让移动距离最短,那么至少要使一个雕塑 ...
- 计算机二级-C语言-程序填空题-190117记录-对文件的处理,复制两个文件,往新文件中写入数据。
//给定程序的功能是,调用函数fun将指定源文件中的内容赋值到指定目标文件中,复制成功时函数返回1,失败时返回0,把复制的内容输出到终端屏幕.主函数中源文件名放在变量sfname中,目标文件名放在变量 ...
- jdk rpm安装实现
wget https://download.oracle.com/otn/java/jdk/8u211-b12/478a62b7d4e34b78b671c754eaaf38ab/jdk-8u211 ...