洛谷 P4697 Balloons [CEOI2011] 单调栈/dp (待补充qwq)
正解:单调栈/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)的更多相关文章
- 洛谷P4198 楼房重建 单调栈+线段树
正解:单调栈+线段树 解题报告: 传送门! 首先考虑不修改的话就是个单调栈板子题昂,这个就是 然后这题的话,,,我怎么记得之前考试好像有次考到了类似的题目昂,,,?反正我总觉着这方法似曾相识的样子,, ...
- 洛谷P4147 玉蟾宫 单调栈/悬线法
正解:单调栈/悬线法 解题报告: ummm这题我当初做的时候一点思路也没有只会暴力出奇迹:D(啊听说暴力好像能水过去呢,,, 然后当初是看的题解,然后学了下悬线法 然后就忘了:D 然后我现在看发现看不 ...
- 洛谷P3400 仓鼠窝(单调栈)
P3400 仓鼠窝 题目描述 萌萌哒的Created equal是一只小仓鼠,小仓鼠自然有仓鼠窝啦. 仓鼠窝是一个由n*m个格子组成的行数为n.列数为m的矩阵.小仓鼠现在想要知道,这个矩阵中有多少个子 ...
- 洛谷 P1198 [JSOI2008]最大数——单调栈/线段树
先上一波题目 https://www.luogu.org/problem/P1198 题目要求维护后缀最大值 以及在数列的最后面添加一个数 这道题呢我们有两种做法 1.单调栈 因为只需要维护后缀最大值 ...
- 洛谷P1950 长方形(单调栈)
一道单调栈的好题啊...... 思路是很奇妙的,对于每个点(i,j),我们可以算它对答案的贡献(即包含它的矩形数量),包含该点的矩形,点的高度为h[j],点右边的高度一定大于等于h[j],左边的高度一 ...
- 洛谷 P4072 [SDOI2016]征途 斜率优化DP
洛谷 P4072 [SDOI2016]征途 斜率优化DP 题目描述 \(Pine\) 开始了从 \(S\) 地到 \(T\) 地的征途. 从\(S\)地到\(T\)地的路可以划分成 \(n\) 段,相 ...
- 洛谷P2507 [SCOI2008]配对 题解(dp+贪心)
洛谷P2507 [SCOI2008]配对 题解(dp+贪心) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1299251 链接题目地址:洛谷P2507 [S ...
- 洛谷 P3177 [HAOI2015]树上染色 树形DP
洛谷 P3177 [HAOI2015]树上染色 树形DP 题目描述 有一棵点数为 \(n\) 的树,树边有边权.给你一个在 \(0 \sim n\)之内的正整数 \(k\) ,你要在这棵树中选择 \( ...
- Codeforces 1383E - Strange Operation(线段树优化 DP or 单调栈+DP)
Codeforces 题目传送门 & 洛谷题目传送门 Yet another 自己搞出来的难度 \(\ge 2800\) 的题 介绍一个奇奇怪怪的 \(n\log n\) 的做法.首先特判掉字 ...
随机推荐
- Perl socket编程
In this article, let us discuss how to write Perl socket programming using the inbuilt socket module ...
- FFMPEG转换WAV到MP3
下载FFMPEG https://ffmpeg.zeranoe.com/builds/ Example to encode VBR MP3 audio with ffmpeg using the li ...
- 细说php的异常和错误处理机制
再谈php错误与异常处理 讲的非常好 w3school php异常处理机制 php错误异常处理详解 注: 关注set_error_handler() set_exception_handler() r ...
- linux sumba服务器简单配置
使用samba设置linux和windows直接简单的文件共享 前提: 1.linux和windows已经可以互相ping同 2.已经安装好smb 查看是否安装smb rpm -aq|grep smb ...
- 《Lua程序设计》第1章 开始 学习笔记
1.1 程序块(chunk)每段代码(例如一个源代码文件或在交互模式中输入的一行代码),称为一个程序块.若使用命令行参数-i来启动Lua解释器,那么解释器就会在运行完指定程序块后进入交互模式.dofi ...
- django restframwork 教程之authentication权限
当前我们的API在编辑或者删除的时候没有任何限制,我们不希望有些人有高级的行为,确保: 代码段始终与创建者相关联 只允许授权的用户可以创建代码段 只允许代码段创建者可以更新和删除 没有认证的请求应该有 ...
- 百度地图API接口
js <script type="text/javascript"> // 百度地图API功能 var map = new BMap.Map("map&quo ...
- PowerDesigner快捷键【转】
一般快捷键 快捷键 说明 F4 打开检查模型窗口,检查模型 F5 如果图窗口内的图改变过大小,恢复为原有大小即正常大小 F6 放大图窗口内的图 F7 缩小图窗口内的图 F8 在图窗口内中查看全部图内容 ...
- C++中三种创建对象的方法【转】
我们都知道C++中有三种创建对象的方法,如下: #include <iostream> using namespace std; class A { private: int n; pub ...
- Money型字段小数点后保留两位小数
asp.net直接显示Money型字段小数点后面将保留四位小数,而我们常见的格价显示一般是小数点后两位,如何实现这种效果呢,有如下几种方法: 1.直接型,通过ToString()函数直接格式话 例如把 ...