博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Codeforces Round #514 (Div. 2)
阅读量:5322 次
发布时间:2019-06-14

本文共 669 字,大约阅读时间需要 2 分钟。

D. Nature Reserve

题目描述:给定\(n\)个点,找出一个圆,使得这个圆与\(y\)轴相切并且包含所有的点,问最小半径。

solution

解法倒是挺套路的。二分答案,求出每个点对应的圆心可行域,判断有没有交集。问题是答案可能会很大,要用long double,而我二分又习惯了用eps来判断退出,但因为精度的问题,这个条件基本不会退出,所以以后碰到二分小数的,还是直接枚举二分次数比较好。

时间复杂度:\(O(能过)\)

E. Split the Tree

题目描述:有一棵树,每个点有一个权值,现在要用\(m\)条路径来覆盖这棵树,每条路径后一个点要是前一个点的父亲,路径上所有点的权值和不能超过\(S\),点数不能超过\(L\),路径不能有相交部分,问\(m\)的最小值。

solution

首先,路径不能有相交部分这个条件是没有用的,因为就算有相交的部分,也可以通过调整使得不相交。暴力维护每个点的子树的叶子延伸到这个点的每条路径的点数和总和,不符合条件的不延伸,如果没有路径延伸到这个点,那说明这个点要作为路径开头,答案加一。这竟然能过。

其实可以先倍增预处理出每个点最远可以向上走多远,然后对于每个点,只有一条路径可以穿过这个点继续往上走,那显然要选一条往上走能走最远的那条路径,其它路径不延伸,如果没有一条路径能穿过这个点,那答案就要加一,这个点作为开头往上走。

时间复杂度:\(O(nlogn)\)

转载于:https://www.cnblogs.com/GerynOhenz/p/9746805.html

你可能感兴趣的文章
通过maven profile 打包指定环境配置
查看>>
redis 存储时间区间的数据
查看>>
STM32F0库函数初始化系列:进入STOP模式,外部中断唤醒
查看>>
p1525 关押罪犯
查看>>
使用Html5shiv.js让ie支持html5
查看>>
DBA 优化法则
查看>>
用Python连接SQLServer抓取分析数据、监控 (pymssql)
查看>>
升级ruby后再安装cocodPod
查看>>
MySQL数据库8(十三)高级数据操作之select指令
查看>>
随心测试_Python Se_002<不同浏览器驱动>
查看>>
LeetCode 202. Happy Number
查看>>
【Codeforces Round #432 (Div. 2) A】 Arpa and a research in Mexican wave
查看>>
HTTP协议
查看>>
转载 jenkins执行selenium 测试 浏览器不显示解决方法
查看>>
spring+mybatis利用interceptor(plugin)兑现数据库读写分离
查看>>
wenbao与极角排序
查看>>
回顾JAVA---3.异常
查看>>
data Binding
查看>>
SSM配置
查看>>
HDU 5957 Query on a graph
查看>>