第k短路径_利用标幺值进行短路计算

第k短路径_利用标幺值进行短路计算给定一张 N 个点(编号 1,2…N),M 条边的有向图,求从起点 S 到终点 T 的第 K 短路的长度,路径允许重复经过点或边。注意: 每条最短路中至少要包含一条边。输入格式第一行包含两个整数 N 和 M。接下来 M 行,每行包含三个整数 A,B 和 L,表示点 A 与点 B 之间存在有向边,且边长为 L。最后一行包含三个整数 S,T 和 K,分别表示起点 S,终点 T 和第 K 短路。输出格式输出占一行,包含一个整数,表示第 K 短路的长度,如果第 K 短路不存在,则输出 −1。数据范围

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

给定一张 N 个点(编号 1,2…N),M 条边的有向图,求从起点 S 到终点 T 的第 K 短路的长度,路径允许重复经过点或边。

注意: 每条最短路中至少要包含一条边。

输入格式
第一行包含两个整数 N 和 M。

接下来 M 行,每行包含三个整数 A,B 和 L,表示点 A 与点 B 之间存在有向边,且边长为 L。

最后一行包含三个整数 S,T 和 K,分别表示起点 S,终点 T 和第 K 短路。

输出格式
输出占一行,包含一个整数,表示第 K 短路的长度,如果第 K 短路不存在,则输出 −1。

数据范围
1≤S,T≤N≤1000,
0≤M≤105,
1≤K≤1000,
1≤L≤100
输入样例:
2 2
1 2 5
2 1 4
1 2 2
输出样例:
14

题解
A*算法,第二次弹出来的值位第二小的值.

#include<bits/stdc++.h>
using namespace std;
typedef pair<int,int>PII;
typedef pair<int,pair<int,int> >PIII;
const int N = 1e3 + 10;
const int M = 1e5 + 10;
#define x first
#define y second
const int INF = 0x3f3f3f3f;
struct Edge{ 
   
    int v,next,w;
}edge[M];
int head[N],cnt;
int dist[N],vis[N];
void add(int u,int v,int w){ 
   
    edge[cnt].v = v;
    edge[cnt].w = w;
    edge[cnt].next = head[u];
    head[u] = cnt ++;
}
int f(int ver){ 
   
    return dist[ver];
};
int dijstra(int s,int e){ 
   
    memset(dist,INF,sizeof dist);
    priority_queue<PII,vector<PII>,greater<PII> >pq;
    dist[e] = 0;
    pq.push({ 
   dist[e],e});
    while(!pq.empty()){ 
   
        int ver = pq.top().y;
        pq.pop();
        if(vis[ver])continue;
        vis[ver] = true;
        for(int i = head[ver];~i;i = edge[i].next){ 
   
            if(!(i & 1))continue;
            int v = edge[i].v,w = edge[i].w;
            if(dist[v] > dist[ver] + w)
            { 
   
                dist[v] = dist[ver] + w;
                pq.push({ 
   dist[v],v});
            }
        }
    }
    if(dist[s] == INF)return -1;
}

int Astar(int s,int e,int K){ 
   
    int num = 0;
    int ddist[N];
    priority_queue<PIII,vector<PIII>,greater<PIII> >pq;
    ddist[s] = 0;
    pq.push({ 
   ddist[s] + f(s),{ 
   ddist[s],s}});
    
    while(!pq.empty()){ 
   
        PIII tt = pq.top();
        int ver = pq.top().y.y,distance = pq.top().y.x;
        pq.pop();
        if(ver == e)num ++;
        if(num == K)return tt.y.x;
        
        for(int i = head[ver];~i;i = edge[i].next){ 
   
            if((i & 1))continue;
            int v = edge[i].v,w = edge[i].w;
            ddist[v] = distance + w;
            pq.push({ 
   ddist[v] +  f(v),{ 
   ddist[v],v}});
        }
    }
    
    return -1;
}

int main(){ 
   
    int n,m,k;
    cin>>n>>m;
    int x,y,w;
    int S,T,K;
    memset(head,-1,sizeof head);
    for(int i = 0;i < m;i ++){ 
   
        cin>>x>>y>>w;
        add(x,y,w);
        add(y,x,w);
    }
    cin>>S>>T>>K;
    if(S == T) K ++;
    if(dijstra(S,T) == -1)cout<<-1<<endl;
    else cout<<Astar(S,T,K)<<endl;
    
    
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/168632.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • c++解决大整数乘法

    c++解决大整数乘法c++解决大整数乘法问题描述:求两个不超过200位的非负整数的积输入数据:输入有两行,每行是一个不超过200位的非负整数,没有多余的前导0。输出要求:输出只一行,即相乘后的结果。结果里不能有多余的前导0,即如果结果是342,那么不能输出0342。输入样例:1234567890098765432100输出样例:1219326311126352690000解题思路:采用列乘法竖式的求解思路,采用数组…

  • C++ Primer笔记7_STL之关联容器

    C++ Primer笔记7_STL之关联容器

  • sqlyog激活成功教程版_sqlyog10.0安装教程

    sqlyog激活成功教程版_sqlyog10.0安装教程链接:https://pan.baidu.com/s/1N3ufWDe-CKj4QvNIz8vXpA提取码:95hm直接安装接着用压缩白内的文档注册码注册即可使用。

  • turtle(海龟作图),C++版「建议收藏」

    turtle(海龟作图),C++版「建议收藏」海龟作图引言turtle来源Logo的原型来自另一个计算机语言LISP,派普特修改了LISP的语法使其更易于阅读。Logo常被称作没有括号的Lisp。Logo是一种解释型语言,和其他语言不同的是,它内置一套海龟绘图(TurtleGraphics)系统,通过向海龟发送命令,用户可以直观地学习程序的运行过程,因此很适于儿童学习。它亦适合用作数学教学。海龟绘图使得Logo用户可以通过简单的编程创作出丰富多彩的视觉效果或图案。假想一只带着画笔的海龟可以接受简单的命令,例如向前走100步,或者左转30度。

  • python转置矩阵代码_python 矩阵转置[通俗易懂]

    python转置矩阵代码_python 矩阵转置[通俗易懂]用python怎么实现矩阵的转置只能用循环自己写算法吗自带函数有可以算的吗或者网上的算法可以用的python矩阵转置怎么做?5.矩阵转置给定:L=[[1,2,3],[4,5,6]]用zip函数和列表推导式实现行列转deftranspose(L):T=[list(tpl)fortplinzip(*L)]returnTpython字符串如何变成矩阵进行矩阵转置如输入一串“…

  • Python调用百度云api,实现截图图片文字识别

    Python调用百度云api,实现截图图片文字识别调用百度云api,实现截图图片文字识别相信大家在网上查找资料时都会遇到一些类似于pdf格式的文档,无法直接复制,手打太过于浪费时间。那么在这里我分享一个调用百度云api文字识别接口识别此类文字的python小程序。本人刚学习python时间不长,如果内容有错误还望斧正。首先我们需要去百度云官网申请一个接口点击立即使用创建应用填写需要填写的数据后点击立即创建,即可创建成功此时我们…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号