【最短路】【SPFA】单源最短路径 (luogu 3371)

单源最短路径

luogu 3371

题目大意:

求出一个点到其他点的最短路

原题:

题目背景

本题测试数据为随机数据,在考试中可能会出现构造数据让SPFA不通过,如有需要请移步 P4779。

题目描述

如题,给出一个有向图,请输出从某一点出发到所有点的最短路径长度。

输入输出格式

输入格式:

第一行包含三个整数N、M、S,分别表示点的个数、有向边的个数、出发点的编号。
接下来M行每行包含三个整数Fi、Gi、Wi,分别表示第i条有向边的出发点、目标点和长度。

输出格式:

一行,包含N个用空格分隔的整数,其中第i个整数表示从点S出发到点i的最短路径长度(若S=i则最短路径长度为0,若从点S无法到达点i,则最短路径长度为2147483647)

输入输出样例

输入样例#1:

4 6 1
1 2 2
2 3 2
2 4 1
1 3 5
3 4 3
1 4 4

输出样例#1:

0 2 4 3

说明

时空限制:

1000ms,128M

数据规模:

对于20%的数据:N<=5,M<=15;
对于40%的数据:N<=100,M<=10000;
对于70%的数据:N<=1000,M<=100000;
对于100%的数据:N<=10000,M<=500000。保证数据随机。
对于真正 100% 的数据,请移步 P4779。请注意,该题与本题数据范围略有不同。

样例说明:

在这里插入图片描述
图片1到3和1到4的文字位置调换

解题思路:

用SPFA求出起点到其他点的最短路,然后循环一遍输出即可

代码:

#include<cstdio>
#include<cstring>
#include<iostream>
#include<queue>
using namespace std;
int n,m,ks,x,y,s,now,head[10005],b[10005],p[10005];
struct rec
{int to,l,next;
}a[500001];
int main()
{scanf("%d %d %d",&n,&m,&ks);//输入for (int i=1;i<=m;++i){scanf("%d %d %d",&x,&y,&s);a[i].to=y;//链表存法a[i].l=s;a[i].next=head[x];head[x]=i;}fill(b+1,b+1+n,2147483647);//处值queue<int> d;//STL队列d.push(ks);//入队b[ks]=0;//预处理p[ks]=1;while (!d.empty())//不为空{now=d.front();//取出来d.pop();//出队for (int i=head[now];i;i=a[i].next)//连接此点的每一条边if (b[now]+a[i].l<b[a[i].to])//更优{b[a[i].to]=b[now]+a[i].l;//代替if (!p[a[i].to])//判断是否需要入队{d.push(a[i].to);p[a[i].to]=1;}}p[now]=0;//清零}for (int i=1;i<=n;++i)if (i==ks) printf("0 ");//判断else printf("%d ",b[i]);//输出
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/321177.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P59330-[清华集训2012]串珠子【状压dp】

正题 题目链接:https://www.luogu.com.cn/problem/P5933 题目大意 nnn个点的一张无向图&#xff0c;求所有联通子图的权值乘积和 解题思路 因为nnn很小&#xff0c;考虑状压 设fif_ifi​表示点集为iii时的方案数&#xff0c;我们发现正着做十分麻烦&#xff0c;考虑容斥。 首…

codeforces gym-101736 Dessert First Strategy 最小割

题目 题目链接 题解 很典型的最小割模型问题&#xff0c;我们知道颜色不确定的点最终要么是白色&#xff0c;要么是黑色&#xff0c;是两种对立的状态&#xff0c;我们联想到了最小割。 最小割是割掉权值和最小的边集&#xff0c;使得图中的点分成两个点集&#xff0c;一个…

在Windows 下如何使用 AspNetCore Api 和 consul

一、概念&#xff1a;什么是consul:Consul 是有多个组件组成的一个整体&#xff0c;作用和Eureka,Zookeeper相当&#xff0c;都是用来做服务的发现与治理。 Consul的特性&#xff1a;1、 服务的发现&#xff1a;consul可以把注册到其中的服务提供给使用者&#xff0c;也可以主动…

CF590E-Birthday【AC自动机,最大独立集】

正题 题目链接:https://www.luogu.com.cn/problem/CF590E 题目大意 nnn个字符串&#xff0c;求一个最大的集合使其中没有任何串是其他集合内字符串的子串 解题思路 先用ACACAC自动机建立好failfailfail树传递闭包就可以确定好两两之间的子串关系了&#xff0c;之后用网络流最…

【最短路】【SPFA】电车 (luogu 1346)

电车 luogu 1346 题目大意&#xff1a; 有n个点&#xff0c;要从一个点到另一个点&#xff0c;每个点连接着其他ai个点&#xff0c;到连接的第一个点路径长度为0&#xff0c;其他长度为1&#xff0c;求最短路 题目描述 在一个神奇的小镇上有着一个特别的电车网络&#xff…

网络流及建模专题(下)

前言 不断更新中… 专题的(下)篇将介绍网络流的一些奇奇怪怪的应用和费用流有关的一些套路。 本专题暂时包含三道题&#xff1a; 洛谷P1251 餐巾计划问题: 费用流的基本应用 Trade Gym - 100212I: 使用网络流对图论中的边进行调整 codeforces 818G - Four Melodies: 费用…

CentOS 7.4 下 如何部署 AspNetCore 结合 consul

上篇我们讲到consul的概念&#xff0c;以及在WIN下如何使用&#xff1a; 在Windows 下如何使用 AspNetCore Api 和 consul步骤如下&#xff1a;1、安装虚拟机VM 2、下载安装 CentOS 7.4&#xff08;地址就不提供了&#xff09;这是安装示例&#xff1a; VM虚拟机安装CentOS 示例…

P4083-[USACO17DEC]A Pie for a Pie G【线段树,最短路】

正题 题目链接:https://www.luogu.com.cn/problem/P4083 题目大意 开始时AAA和BBB各有两个礼物&#xff0c;每个礼物对两个人有不同的价值&#xff0c;开始时AAA会送BBB一个礼物。 对于一个收到礼物的人&#xff0c;如果该礼物对他来说价值为valvalval&#xff0c;那么他会回…

【SPFA】最优贸易(luogu 1073)

最优贸易 luogu 1073 题目大意&#xff1a; 有n个城市和m条线路连接着这些城市&#xff08;当编号为1时是有向&#xff0c;2时是无向&#xff09;&#xff0c;从1城市出发到n城市&#xff0c;每个城市都有固定的水晶球价格&#xff08;进价和售价一样&#xff09;&#xff0…

Razor Page Library:开发独立通用RPL(内嵌wwwroot资源文件夹)

Demo路径&#xff1a;https://github.com/yanshengjie/RPL.Demo1. IntroductionRazor Page Library 是ASP.NET Core 2.1引入的新类库项目&#xff0c;属于新特性之一&#xff0c;用于创建通用页面公用类库。也就意味着可以将多个Web项目中通用的Web页面提取出来&#xff0c;封装…

Problem H Rock Paper Scissors,FFT

题目 题目链接 题意 给出两段石头剪刀布的顺序SS和T" role="presentation" style="position: relative;">TT&#xff0c;其中TT要短一些,现在让你把T" role="presentation" style="position: relative;">TT往SS的…

CF1066F-Yet another 2D Walking【贪心】

正题 题目链接:https://www.luogu.com.cn/problem/CF1066F 题目大意 平面上有nnn个点&#xff0c;每个点在max(x,y)max(x,y)max(x,y)层&#xff0c;走第kkk层的点之前一定要先走前面层的点&#xff0c;求走完所有点的最短路。 解题思路 对于每一层来说&#xff0c;我们可以将…

【最短路】【SPFA】城市问题(ssl 1761)

城市问题 ssl 1761 题目大意&#xff1a; 求一个点到其它点的最短路 原题&#xff1a; Description 设有n个城市&#xff0c;依次编号为0&#xff0c;1&#xff0c;2&#xff0c;……&#xff0c;n-1&#xff08;n<100&#xff09;&#xff0c;另外有一个文件保存n个城…

.NET Core微服务之基于Ocelot实现API网关服务

一、啥是API网关&#xff1f;API 网关一般放到微服务的最前端&#xff0c;并且要让API 网关变成由应用所发起的每个请求的入口。这样就可以明显的简化客户端实现和微服务应用程序之间的沟通方式。以前的话&#xff0c;客户端不得不去请求微服务A&#xff08;假设为Customers&am…

P3157 动态逆序对 ,树状数组套动态开点线段树

题目 洛谷题目链接 题解 在求整体的逆序对的数量时&#xff0c;很好办&#xff0c;直接用树状数组处理即可&#xff0c;不过在这时&#xff0c;我们还需要处理出一个数组pa[]pa[]pa[]&#xff0c;其中pa[i]pa[i]pa[i]代表在区间[1,i)[1,i)[1,i)中满足aj>aia_j>a_iaj​…

【DP】猫咪的进化

猫咪的进化 题目大意&#xff1a; 有n个实数&#xff0c;每一个实数可以选&#xff0c;可以不选&#xff0c;也可以选择它的平方&#xff0c;但如果选择了它的平方&#xff0c;就不能选择下一个数或下一个数的平方&#xff0c;求选出来的数的和最大是多少 原题&#xff1a; …

[8.21NOIP模拟赛]决战【tarjan】

正题 题目大意 nnn个点mmm条边的联通图&#xff0c;去掉一个点使得其变为一棵树 求能去掉哪些点 解题思路 首先去掉后就是一棵n−1n-1n−1个节点的树&#xff0c;也就是有n−2n-2n−2条边&#xff0c;这样我们就需要去掉m−n2m-n2m−n2条边&#xff0c;也就是去掉入度为m−n2…

[译]RabbitMQ教程C#版 - 发布订阅

先决条件本教程假定RabbitMQ已经安装&#xff0c;并运行在localhost标准端口&#xff08;5672&#xff09;。如果你使用不同的主机、端口或证书&#xff0c;则需要调整连接设置。从哪里获得帮助如果您在阅读本教程时遇到困难&#xff0c;可以通过邮件列表联系我们。1.发布/订阅…

P2468 [SDOI2010]粟粟的书架 动态规划,主席树,二分答案

题目 洛谷题目链接 题解 题目的数据范围非常奇怪&#xff0c;一半是200∗200200∗200的矩阵&#xff0c;另一半是1∗500001∗50000的矩阵&#xff0c;显然是一道二合一的题目&#xff0c;但是不一样的地方也就在与数据结构的选择不一样&#xff0c;而我们解这道题使用的算法…

nssl1511-我的世界【堆,贪心】

正题 题目大意 nnn个点的一棵树&#xff0c;给每一个点一个权值&#xff0c;每个点的依靠点是与它相连的权值最小的点&#xff0c;要求每个点最多只有一个依赖点。 求字典序最小的方案 解题思路 首先最小的一定是叶子结点&#xff0c;然后他的父节点指向他&#xff0c;因为它…