正解:单调栈/dp

解题报告:

先放个传送门qwq

话说这题是放在了dp的题单里呢?但是听说好像用单调栈就可以做掉所以我就落实下单调栈的解法好了qwq

(umm主要如果dp做好像是要斜率优化凸壳维护双端队列巴拉巴拉可能要以后再来搞了qwq)

先解释题意...我觉得我是傻逼,,,这题我因为没懂题意卡了好几周了有...

是酱婶的,就是说给一些气球,开始它们都只是瘪的,都还没打气

然后给你这些气球的横坐标和最大半径

然后问你,我现在一个个给气球打气,打到不能打为止,问你每个气球的半径

(,,,我之前一直傻逼地以为是每个气球已经飘起来了然后给你飘着的纵坐标问你rmax,,,导致我一度没懂这题QAQ直到问大佬这题才明白题意,,,果然还是我太傻逼QAQ

首先还是比较简单地能推出,如果给气球i充气的时候和j相撞了,ri=(xi-xj)2/4rj这个还比较容易推画个图就能发现不详说了qwq

然后如果我们每次都一个个枚举我们要充的这个气球会和哪个气球相撞显然是不现实的,复杂度过不去,考虑怎么降复杂度

可以先思考怎么样一个气球是绝对不会有贡献的:

1)如果后面有个气球半径比前面的大,前面的显然是不会产生贡献了,这个比较好理解的哦就不详细解释辣qwq

  →这个性质就告诉我们,可以维护一个x递增r递减的单调栈

2)如果我从当前气球往前枚举,到了某个气球的时候ri已经小于rj了,那j之前的气球显然也不会产生贡献了(解释在后面qwq)

  →这个性质的话就可以使它做到一半就能得到答案不用一直一直做下去,降低复杂度

然后这样的话就成功从n2降到了n!

over

(

哦关于第二个性质的理解,我强行理解了一波

先定义一下我现在在做的气球叫i,找到的ri<rj的气球叫j,当前枚举的j之前的气球叫k,当前用公式算出来的ri叫ri,算到j的时候小于了rj的i的r叫真实ri,同理rj真实rj,那当前的rj显然是算的rj=(xj-xk)2/4rk算出来的

因为显然ri必大于rj必大于真实rj必大于真实ri所以就欧克了×

ummm详细说下,我之前理解了然后再想一遍就又理解了半天QAQ所以还是详细写下趴QAQ不然估计之后每次还是要理解半天QAQ

由已知得xi>xj>xk,所以ri>rj

又因为rj>=真实rj,所以ri>真实rj

又因为真实rj>真实ri,所以ri>真实ri

显然的是r是要取最小值的嘛

所以当ri<rj的时候就可以停止了

over!

洛谷 P4697 Balloons [CEOI2011] 单调栈/dp (待补充qwq)的更多相关文章

  1. 洛谷P4198 楼房重建 单调栈+线段树

    正解:单调栈+线段树 解题报告: 传送门! 首先考虑不修改的话就是个单调栈板子题昂,这个就是 然后这题的话,,,我怎么记得之前考试好像有次考到了类似的题目昂,,,?反正我总觉着这方法似曾相识的样子,, ...

  2. 洛谷P4147 玉蟾宫 单调栈/悬线法

    正解:单调栈/悬线法 解题报告: ummm这题我当初做的时候一点思路也没有只会暴力出奇迹:D(啊听说暴力好像能水过去呢,,, 然后当初是看的题解,然后学了下悬线法 然后就忘了:D 然后我现在看发现看不 ...

  3. 洛谷P3400 仓鼠窝(单调栈)

    P3400 仓鼠窝 题目描述 萌萌哒的Created equal是一只小仓鼠,小仓鼠自然有仓鼠窝啦. 仓鼠窝是一个由n*m个格子组成的行数为n.列数为m的矩阵.小仓鼠现在想要知道,这个矩阵中有多少个子 ...

  4. 洛谷 P1198 [JSOI2008]最大数——单调栈/线段树

    先上一波题目 https://www.luogu.org/problem/P1198 题目要求维护后缀最大值 以及在数列的最后面添加一个数 这道题呢我们有两种做法 1.单调栈 因为只需要维护后缀最大值 ...

  5. 洛谷P1950 长方形(单调栈)

    一道单调栈的好题啊...... 思路是很奇妙的,对于每个点(i,j),我们可以算它对答案的贡献(即包含它的矩形数量),包含该点的矩形,点的高度为h[j],点右边的高度一定大于等于h[j],左边的高度一 ...

  6. 洛谷 P4072 [SDOI2016]征途 斜率优化DP

    洛谷 P4072 [SDOI2016]征途 斜率优化DP 题目描述 \(Pine\) 开始了从 \(S\) 地到 \(T\) 地的征途. 从\(S\)地到\(T\)地的路可以划分成 \(n\) 段,相 ...

  7. 洛谷P2507 [SCOI2008]配对 题解(dp+贪心)

    洛谷P2507 [SCOI2008]配对 题解(dp+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1299251 链接题目地址:洛谷P2507 [S ...

  8. 洛谷 P3177 [HAOI2015]树上染色 树形DP

    洛谷 P3177 [HAOI2015]树上染色 树形DP 题目描述 有一棵点数为 \(n\) 的树,树边有边权.给你一个在 \(0 \sim n\)之内的正整数 \(k\) ,你要在这棵树中选择 \( ...

  9. Codeforces 1383E - Strange Operation(线段树优化 DP or 单调栈+DP)

    Codeforces 题目传送门 & 洛谷题目传送门 Yet another 自己搞出来的难度 \(\ge 2800\) 的题 介绍一个奇奇怪怪的 \(n\log n\) 的做法.首先特判掉字 ...

随机推荐

  1. CMake设置输出目录

    set(CMAKE_ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/Lib)set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${CMAK ...

  2. 在 Ubuntu 中安装 MySQL 指南

    安装MySQL 在Ubuntu上可以使用Ubuntu Software Center或者apt命令来安装MySQL,两种方式都十分方便. 1. 使用Ubuntu Software Center:打开U ...

  3. [转]logging使用

    来源:https://www.cnblogs.com/nancyzhu/p/8551506.html日志 日志是跟踪软件运行时所发生的事件的一种方法.软件开发者在代码中调用日志函数,表明发生了特定的事 ...

  4. 音频——H5 audio

    分享站又有新功能了:将文件站上的语音文件正确播放出来.效果图: 暂停: 播放: 实现的效果:类似于音乐播放器一般,但是较之更简单一些,可以正常播放语音,有拖动.快进后退效果便可. 思路: 首先想到的便 ...

  5. Java读取maven目录下的*.properties配置文件

    public class ReadProperties{ private static String proFileName = "/config/MQSubjectId.propertie ...

  6. 在RDLC报表中对纸张的设置

    RDLC报表是存放成XML文件格式的,这一点你可以直接打开RDLC报表文件看一下,而且在使用时,通过ReportViewer来读取报表并与数据源进行合成,也就是说RDLC是定义了一个格式,那就不能通过 ...

  7. Windows 下 Tomcat 添加为系统服务

    标记一下,以便以后查看 setclasspath.bat 第一行插入 SET JAVA_HOME=C:\Program Files\Java\jre1.8.0_51 service.bat 第一行插入 ...

  8. 【基础知识】列一下一个.Net WEB程序员需要掌握的知识

    基础部分 C# 基础语法 OOP的概念,面向对象的理解 继承 封装 多态 ASP.NET MVC (Web Form 用的越来越少,如果你不熟悉,可以不看) JavaScript 基础语法 如何在HT ...

  9. mysqlint类型的长度值mysql在建表的时候int类型后的长度代表什么

    详解mysql int类型的长度值 mysql在建表的时候int类型后的长度代表什么 是该列允许存储值的最大宽度吗 为什么我设置成int(1), 也一样能存10,100,1000呢. 当时我虽然知道i ...

  10. 题目1459:Prime ring problem(素数环问题——递归算法)

    题目链接:http://ac.jobdu.com/problem.php?pid=1459 详解链接:https://github.com/zpfbuaa/JobduInCPlusPlus 参考代码: ...