第k短路径_典型的分类算法K均值

第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/169120.html原文链接:https://javaforall.cn

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

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

(0)


相关推荐

  • Bass库Mp3转wav、samplerate/channel修改[通俗易懂]

    Bass库Mp3转wav、samplerate/channel修改[通俗易懂]代码地址:https://download.csdn.net/download/qq_14931305/10803169Bass库官网:http://www.un4seen.com/Bass库参考文档:http://www.un4seen.com/doc/#bass/bass.html1.Bass库集成集成请参考我之前的博客:https://blog.csdn.net/qq_149…

  • 渗透测试工具Burp Suite详解[通俗易懂]

    渗透测试工具Burp Suite详解[通俗易懂]BurpSuite的安装BurpSuite是一款集成化的渗透测试工具,包含了很多功能,可以帮助我们高效地完成对Web应用程序的渗透测试和攻击。BurpSuite由Java语言编写,基于Java自身的跨平台性,使这款软件学习和使用起来更方便。BurpSuite不像其他自动化测试工具,它需要手工配置一些参数,触发一些自动化流程,然后才会开始工作。BurpSuite可执行程序是Java文件类型的jar文件,免费版可以从官网下载。免费版的BurpSuite会有许多限制,无法使用很多高

  • 观察者模式是非常常用的设计模式_实现一个观察者模式

    观察者模式是非常常用的设计模式_实现一个观察者模式好久没有写博客啦,之前看完了《设计模式之禅》也没有总结一下,现在回忆一下设计模式之观察者模式。1.什么是观察者模式简单情形:有A、B、C、D等四个独立的对象,其中B、C、D这三个对象想在A对象发生改

  • MotionEvent的getX(),getY()与getRawX(),getRawY()区别

    MotionEvent的getX(),getY()与getRawX(),getRawY()区别

  • 局域网和广域网_简单的局域网怎么搭建

    局域网和广域网_简单的局域网怎么搭建局域网1、什么是局域网:局域网是封闭型的,可以由办公室内的两台计算机组成,也可以由一个公司内的上千台计算机组成。也称为内网。2、局域网怎么实现:以太网是全球使用最广泛的局域网技术,有线局域网通常通过双绞线(一般直接说网线)连接;无线局域网现在一般通过交换机、路由器实现。3、局域网可以干什么:局域网可以实现文件管理、应用软件共享、打印机共享、工作组内的日程安排、电子邮件和传真通信服务等功能。广域网1、什么是广域网:将各局域网或城域网连接起来便是广域网,也称为外网或公网。2、广域网怎么实现:现在的传

    2022年10月19日
  • RedisClient的安装及基本使用[通俗易懂]

    RedisClient的安装及基本使用[通俗易懂]管理redis的可视化客户端目前较流行的有三个:RedisClient;RedisDesktopManager;RedisStudio.这里目前给大家介绍RedisClient的下载安装及基本使用。RedisClient是Redis客户端的GUI工具,使用Javaswt和jedis编写,可以方便开发者浏览Redis数据库。该软件支持简体中文,非常适合国内用户使用,不需要汉化就可以直接使用。RedisClient将redis数据以资源管理器的界面风格呈现给用户,可以帮助redis

发表回复

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

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