青岛oj集训5

news/2025/4/3 2:14:48/文章来源:https://www.cnblogs.com/yongshao/p/18805089

Floyd算法——全源最短路

cerr:标准输出错误流:不会输出到freopen制定的out文件中,而是会输出到错误文件中。

提交上去无论加不加freopen,哪怕是提交到洛谷,也只是比较out文件中的值,而不会管cerr输出的东西

好处:调试的时候用cerr,哪怕忘删调试调试

例题1:传递闭包

floyd可以直接算,但复杂度太高

压缩:用bitset优化

bool:00000001/00000000

bitset:1/0

bool&bool运算时间:O(n)

bitset&bitset:O(n/w)(w是机器字长,一般考试是64,即优化速度快了64倍)

这里看一下这的算法:

假设有一条1-2-3-4的链

f[1]=1100,即能到达12点,到不了34

1:1100    由于这里1能够到达2if(f[i][k])成立,才能用2去更新1的所有可达点

2:1110

————

1:1110

3:0111

————

1:1111

这样经过两轮更新,就能到34了

(p.s:其实实际上不是逮着一个点一直更新它,这样可能有更新不到的情况。实际上是先用一个点去更新所有可达点(先枚举k))

例题二:灾后重建

方法一:把所有讯问离线下来,按照t升序进行回答,在排回去

但是这道题保证了Q次讯问的t是不降的,所以就不用离线下来排序了

而且村庄标号越大,解封时间越晚

所以直接枚举点的标号就是解封顺序

用k来代表目前解封到第几个点了

当k<n时(总共就n个点,想干啥)并且k这个点解封的时间早于讯问时间(那么在它之前所有点都解封了)

那么以新解封的k这个点作为中转点,对所有之前的点进行更新

然后再向后探索一个点,知道新的点不存在或未解封

如果讯问的时间中k已经跑过一遍,就不用再跑一遍,直接用这张最后更新的图输出结果就行

输出时要特判:1.起点终点是否尚未解冻2.起点终点之间是否有连线

例题3:无向图的最小问题

假设这个环上就三个点,那么环得长度就是三个点之间的最短路径和

先跑Floyd

假设这三个顶点分别是ijk,那么最短环就是ij+ik+jk之间的最短路

但是一个例子:1-2-3链

很明显:没有环

但是Floyd会将1-3之间强制加上一条长度为1-2+2-3的边

这样程序就会算出最小环位1-2-3-2-1,很明显,有重边,肯定不行

怎么解决?

既然Floyd会强制改变边,那么我们就把边提前备份出来一边,不让Floyd动不就好啦

等用完了再让Floyd动也不迟

代码中mp表示打死不动,我们备份出来的原边长

f代表我们已经用完了,让Floyd去算完的边长

我们先固定下来一个点k,是这个环路径上经过的所有点中编号最大的那个

再枚举两个互不相同的点ij且比k小

kij的环必须是k到i、j的直接路径+i、j之间的最短路径长度

枚举完所有符合条件的环之后,要以k为中转点对所有点更新f数组

因为k以后再也不可能是k了,只能作为最短路径上的中转点

新的一轮ijk,ki、kj都是mp用的直接距离不会有影响

而ij之间的f数组求的是以所有比k小的的点为中转点的最短路

换句话说,ij这条边你就算走出花来,也不可能经过k点或比k更大的点

这样就可以完美地列举所有环了

(倒数第三行的INT_MAX改为1e8)

例题四:Redistributing Gifts S

把最优性转换成可行性问题,用传递闭包解决

建图,如果u看得上v的礼物,觉得v的礼物比他的好,那么就建一条边u->v

然后先跑一遍传递闭包,求出所有可达点

如果i可以到达j点,那么说明i可以拿到j的礼物

最后就输出每一个奶牛,如果它能拿到愿望清单上的1号礼物,就输出1号(不一定就是礼物1,只是排名最靠前的那个)

如果能,就输出完了broke掉,否则就下一个,直到找到最靠前的(肯定能找到的,毕竟自己到自己要设为可达)

代码吗……嘿嘿,手速慢没截到,要不那个时候的我(不会吧?我的博文还有除我以外的人看?)再补上?嘻嘻……反正坑是填不完的嘛

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

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

相关文章

20244214 实验二《Python程序设计》实验报告

20244214 2024-2025-2 《Python程序设计》实验二报告 课程:《Python程序设计》 班级: 2442 姓名: 张家乐 学号:20244214 实验教师:王志强 实验日期:2025年4月1日 必修/选修: 公选课 1.实验内容 (1)设计并完成一个完整的应用程序,完成加减乘除模等运算,功能多多益善。…

langchain0.3教程:聊天机器人进阶之方法调用

大语言模型只能聊天吗?本篇文章将会介绍OpenAI的Function calling原理,以及在Langchain中对应的Tools Calling如何使用,最后将工具调用集成到gradio实现可视化聊天界面。我们思考一个问题:大语言模型是否能帮我们做更多的事情,比如帮我们发送邮件。默认情况下让大模型帮我…

云锵投资 2025 年 3 月简报

季报摘要加密货币高频量化策略,研发中…… 本季度量化基金策略业绩:4.98%,良,全国排名:3975/12416;平均 Beta:1.00; 本季度量化股票策略业绩:5.04%,良,全国排名:3935/12416;平均 Beta:1.46; 本季度量化期权策略业绩:8.69%(中性策略,不参与全国股基排名);(…

【攻防世界】flag_universe

⭕、知识点 流量分析/ftp协议/图片LSB隐写/zsteg 一、题目给出一个流量包二、解题 1、追踪ftp流量 2、查看后发现一些可能有用的信息3、flag.txt里的内容是一串base64编码后的数据,解密后发现是假flag4、根据题目名称以及剩下的两个文件,盲猜答案就隐藏在两张图片中13号流是旧…

20242317 2024-2025-2 《Python程序设计》实验二报告

20242317 2024-2025-2 《Python程序设计》实验二报告 课程:《Python程序设计》 班级:2423 姓名:林楚皓 学号:20242317 实验教师:王志强 实验日期:2025年3月26日 必修/选修:公选课 一、实验内容 1.设计并完成一个完整的应用程序,完成加减乘除模等运算,功能多多益善; …

# **DeepSeek 深度解析 PasteForm:一个让管理端开发爽到飞起的全栈解决方案**

🤖 DeepSeek 深度解析 PasteForm:一个让管理端开发爽到飞起的全栈解决方案 各位开发者注意啦!今天我要带大家全方位解剖 PasteForm 这个神奇框架——不仅介绍核心思想,更要重点展示它强大的配套工具链!(那些被其他教程忽略的精华部分都在这里了!) 先上镇楼图,这是 De…

利用 AWS Signature:REST API 认证的安全指南

随着云计算领域的不断发展,保护 API 访问的安全性变得愈加重要。AWS Signature 提供了一种强大的机制,用于通过 REST API 认证请求到 AWS 服务。本文讨论了 AWS Signature 的重要性,解释了它是什么,提供了 Java 和 Go 中的实现示例,并介绍了用于测试的工具,包括 APIPost,…

【ABP】项目示例(8)——数据迁移

数据迁移 在上一章节中,已经展示了数据播种的用途之一,即单元测试中进行数据初始化,在这一章节中,实现数据播种的另一重要用途,即数据迁移 该项目使用的是代码优先的开发模式,需要将领域模型迁移到数据库中的数据模型 EF数据迁移 在程序包管理控制台选中General.Backend.…

一个测试工程师的实战笔记:我是如何在Postman和Apipost之间做出选择的?

作为一家金融科技公司的测试负责人,我每天要处理数十个需要加密验签的接口。从最开始的Postman,到后来的Apipost,让我重新思考:我们需要的究竟是一个代码编辑器,还是一个真正懂测试者的智能工具? 一、当加密需求被Postman的脚本支配 1、密码字段MD5加密 去年接手支付系统…

【ABP】项目示例(7)——数据播种

数据种子 在上一章节中,已经对仓储层和应用层进行了单元测试,在这一章节中,进行数据播种 大多数程序正常运行都需要依赖于初始数据,依赖于数据库的程序基本都是如此 例如需要有一个初始的管理员用户或者一个管理员角色,用来进行登录系统,像这种主要用于生产环境中的数据播…

kettle从入门到精通 第九十四课 ETL之kettle MySQL Bulk Loader大批量高性能数据写入

1、在使用kettle时如果对表输出性能要求,可以考虑用mysql 批量加载步骤,该步骤可以实现每秒5万+的数据同步(该数据仅是基于我本人的笔记本,若是服务器则效率更高),如下图所示: 2、原理 知其然知其所以然,之所以MySQL Bulk Loader速度如此之快是因为MySQL 批量加载器使用…

Web开发SpringBoot流程性的学习----回顾补充2(YApi)

Vue简述 Vue 是一套前端框架,免除原生JavaScript中的DOM操作,简化书写。 基于MVVM(Model-View-ViewModel)思想,实现数据的双向绑定,将编程的关注点放在数据上。 Vue2官网:https://v2.cn.vuejs.org/生命周期(Vue3已不同)AJAX 概念: Asynchronous JavaScript And XML,异步的…