ssl2661-廉价最短路径【SPFA】

前言

这是一篇迟到的博客


题目

找一条最廉价的最短路径
from ssloj


输入输出(建议无视)

Input

输入文件第一行有两个整数m和n,用一个空格隔开,其中,m是顶点数,而n是边数。接下来的n行给出所有的边及其价值,每行有3个整数(相邻两个整数间有一个空格),表示起点,终点和边的价值。顶点最多有100个,编号在0到99之间。边最多有1000条,其价值在0到2^15-1之间。

Output

输出文件仅有一行包含一个整数,即V0→V1的廉价最短路径的费用。当出现有多个廉价最短路径的情况时,它们的费用是一样的。

Sample Input

4 5
0 2 2
0 3 2
0 1 10
2 1 2
3 1 2

Sample Output

10


解题思路

正常最短路算法,只不过加上一个判断


代码

#include<cstdio>
using namespace std;
struct woc{long long next,x,y,w;
};
woc a[1001];
long long xx,yy,n,m,k,state[101],ls[101],t,head,tail,f[101],s[101];
bool v[101];
int main()
{scanf("%lld%lld",&n,&m);state[1]=1;int u=0;for (int i=1;i<=m;i++){scanf("%lld%lld%lld",&xx,&yy,&a[u+1].w);xx++;yy++;a[++u].next=ls[xx];a[u].x=xx;a[u].y=yy;ls[xx]=u;}for (int i=1;i<=n;i++) {f[i]=2147483647;s[i]=2147483647;}head=0;tail=1;state[1]=1;v[state[1]]=true;f[1]=0; s[1]=0;while (head!=tail)//SPFA{head++;head=(head-1)%n+1;t=ls[state[head]];while (t!=0){if (f[a[t].x]+1<f[a[t].y] || s[a[t].y]>s[a[t].x]+a[t].w && f[a[t].x]+1==f[a[t].y]){s[a[t].y]=s[a[t].x]+a[t].w;//改变价值f[a[t].y]=f[a[t].x]+1;if (!v[a[t].y]){tail++;tail=(tail-1)%n+1;state[tail]=a[t].y;v[a[t].y]=true;}}t=a[t].next;}v[state[head]]=false;}printf("%lld",s[2]);
}

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

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

相关文章

自然语言处理的十个发展趋势

转载自 哈工大刘挺教授&#xff1a;自然语言处理的十个发展趋势 近日&#xff0c;由中国人工智能学会、阿里巴巴集团 & 蚂蚁金服主办&#xff0c;CSDN、中国科学院自动化研究所承办的第三届中国人工智能大会&#xff08;CCAI 2017&#xff09;在杭州国际会议中心盛大开幕…

SpringAOP的Aspectj方式*

SpringAOP的Aspectj介绍 问题: 目前我们已经能够使用SpringAOP的SchemaBased方式来实现功能扩展。在使用SchemaBased方式实现功能扩展时&#xff0c;发现一个扩展代码就需要声明对应的实现了指定的接口的类&#xff0c;这样造成代码的结构体系过于繁杂。一个通知一个类。 解决…

拥抱.NET Core系列:依赖注入(1)

前言 DIP、IoC、DI 说起DI不得不提IoC这个模式&#xff0c;很多人会把DI和IoC混为一谈&#xff0c;但其实这两者是概念和实现的关系。 依赖倒置原则&#xff08;DIP&#xff09;&#xff1a;软件设计原则&#xff0c;要依赖于抽象&#xff0c;不要依赖具体实现。 控制反转&…

来自学长同学分享的学习方法

点击上方蓝色关注我们&#xff01;本文原创&#xff1a;陈浴森同学在科技高度发展的今天&#xff0c;计算机在生活中的作用越来越突出。在学校这一年多的学习当中&#xff0c;我总结了不少的经验&#xff0c;让我在以后的学习当中受益匪浅。一开始没学编程的时候&#xff0c;看…

训练集样本不平衡问题对CNN的影响

转载自 训练集样本不平衡问题对CNN的影响 训练集样本不平衡问题对CNN的影响 本文首发于知乎专栏“ai insight”&#xff01; 卷积神经网络&#xff08;CNN&#xff09;可以说是目前处理图像最有力的工具了。 而在机器学习分类问题中&#xff0c;样本不平衡又是一个经常遇到…

银行转账案例

[1] 案例需求 用户访问登录页面&#xff0c;在页面中输入用户名和密码点击登录&#xff0c;登录成功后 进入到主页中。如果登录败&#xff0c;则在登录页面中提示用户用户名或密码错误。在主页面中&#xff0c;用户在填写银行转账信息&#xff0c;包括:转账账户&#xff0c;转账…

20级、19级 | 一天一瞬间!【日更】

点击上方蓝色关注我们&#xff01;欢迎来到今天的一天一瞬间专栏今天是2020年09月08日&#xff0c;天气状况&#xff1a;炎热。19级目前还是上午上课下午补课&#xff0c;补课私下里和我说&#xff0c;班内学生表现都不错&#xff0c;听罢&#xff0c;甚是开心&#xff0c;不管…

一张图看懂小程序全生态

6月9日小程序发布整半年&#xff0c;这半年里&#xff0c;小程序接连经历了&#xff1a;受追捧——遇冷——质疑——趋于理性的过程。我们对小程序这半年来的产业发展做了全面的梳理&#xff0c;从中可以发现&#xff0c;小程序已俨然形成了自己的生态体系&#xff0c;这一生态…

自然语言处理中的Attention Model:是什么以及为什么[一]

转载自 自然语言处理中的Attention Model&#xff1a;是什么以及为什么[一] 自然语言处理中的Attention Model&#xff1a;是什么以及为什么[一] 1、前言 要是关注深度学习在自然语言处理方面的研究进展&#xff0c;我相信你一定听说过Attention Model&#xff08;后文有时…

204787 ,194787 |0001 1131 0001 4226 7035 ![2480 ]

点击上方蓝色关注我们&#xff01;0006 6143 0037 7139 ,2598 4192 0007 7240 0681 1331 0226 ?6849 ?0784 4104 6943 4149 2418 2345 5116 ,7119 0354 0055 3089 1835 ,5261 1783 0250 2601 0110 0171 ,6290 0138 4972 1421 0055 7820 0087 8010 0138 4104 ?1927 1927 ,076…

DDD理论学习系列(9)-- 领域事件

1. 引言 A domain event is a full-fledged part of the domain model, a representation of something that happened in the domain. Ignore irrelevant domain activity while making explicit the events that the domain experts want to track or be notified of, or whi…

ssl1127-方程的解数【HASH,dfs】

前言 我只是凑数的。 正题 输入输出&#xff08;建议无视&#xff09; Input 第1行包含一个整数n。第2行包含一个整数M。第3行到第n2行&#xff0c;每行包含两个整数&#xff0c;分别表示ki和pi。两个整数之间用一个空格隔开。第3行的数据对应i1&#xff0c;第n2行的数据对应…

自然语言处理中的Attention Model:是什么以及为什么[二]

转载自 自然语言处理中的Attention Model&#xff1a;是什么以及为什么[二] 自然语言处理中的Attention Model&#xff1a;是什么以及为什么[二] 1、Attention Model 图一见下&#xff1a; 图1中展示的Encoder-Decoder模型是没有体现出“注意力模型”的&#xff0c;所以可以…

SpringAOP之代理设计模式

[1]设计模式: 概念: 设计模式其实就是代码的一种结构的设计思路。 好处: 增加代码健壮性 易修改性 可扩展性 设计模式的种类: 三大种类: 建造类设计模式 结构类设计模式 行为类设计模式 参考网址: http://baijiahao.baidu.com/s?id1639156298714178350&wfrspider&forp…

教师节快乐!

点击上方蓝色关注我们&#xff01;今天是个特殊的节日&#xff0c;教师节&#xff0c;从昨天开始就有学生给我发教师节祝福了……诺&#xff0c;发就发了吧&#xff0c;还害羞&#xff01;早上一醒来&#xff0c;就看到同学们在群里发祝福&#xff0c;心理美滋滋的。还有直接改…

如何利用.NET Core搭建跨平台的控制台应用程序

尽管传统意义上来说&#xff0c;.NET是只面向Windows的、闭源的专有平台&#xff0c;然而&#xff0c;传统观念即将被颠覆。新的开源跨平台的.NET Core已经开启&#xff0c;意味着你可以在任意平台写C#或.NET&#xff0c;然后在Windows、Linus和macOS运行。 这个新的.NET平台正…

自然语言处理中CNN模型几种常见的Max Pooling操作

转载自 自然语言处理中CNN模型几种常见的Max Pooling操作 自然语言处理中CNN模型几种常见的Max Pooling操作 CNN是目前自然语言处理中和RNN并驾齐驱的两种最常见的深度学习模型。 图1展示了在NLP任务中使用CNN模型的典型网络结构。 一般而言&#xff0c;输入的字或者词用…

SpringTX

文章目录SpringTX的介绍SpringTX的使用代码示例声明式事务中属性解释SpringBoot中AOP事务配置SpringTX的介绍 问题&#xff1a; 在学习了Spring整合mybatis后&#xff0c;我们可以直接从Spring容器中获取mapper层的实例化对象完成数据库操作。而在业务层方法中很多时候因为业务…

详细整理分层开发步骤!

不点蓝字&#xff0c;我们哪来故事&#xff1f;一、创建数据库&#xff0c;在数据库中创建表二、创建java项目&#xff08;起名要有意义&#xff0c;eg&#xff1a;petSys&#xff09;三、在项目中新建包&#xff0c;包名为&#xff1a;cn.bdqn.petSys.entity四、在cn.bdqn.pet…

.NET 跨平台界面框架和为什么你首先要考虑再三

现在用 C# 来开发跨平台应用已经有很成熟的方案&#xff0c;即共用非界面代码&#xff0c;而每个操作系统搭配特定的用户界面代码。这个方案的好处是可以直接使用操作系统原生的控件和第三方控件&#xff0c;还能够和操作系统深度集成。 这里的深度集成主要是指一些 Windows 专…