正解:单调栈/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. Redis 操作字符串数据

    Redis 操作字符串数据: > set name "Tom" // set 用于添加 key/value 数据,如果 key 存在则覆盖 OK > setnx nam ...

  2. AddComponentRecursively

    class AddComponentRecursively extends ScriptableWizard { var componentName : String = ""; ...

  3. windows下nodejs与coffeeScript环境搭建

    [本文档摘抄自网上资料] 安装NodeJS和CoffeeScript方法 首先安装Node(因为nodeJs是服务器端javascript运行环境),到http://nodejs.org/下载对应格式 ...

  4. 【转载】如何从win8/8.1中文版(核心版)升级到win8/8.1专业版

    最近帮助很多同学从win8/8.1的基础版本 - 中文版(核心版)升级到了专业版,经过咨询,升级系统的最主要原因是中文版(核心版)的功能限制,因为基础版本阉割掉了很多常用的功能,比如组策略,计算机管理 ...

  5. 《转》python学习(12)-列表解析

    转自 http://www.cnblogs.com/BeginMan/p/3164937.html 一.列表解析 列表解析来自函数式编程语言(haskell),语法如下: [expr for iter ...

  6. WP8.1学习系列(第三章)——磁贴和锁屏通知

    一.创建默认磁贴 创建默认磁贴,不需要任何代码只有制作几张图片就可以了. 1.创建工程之后,在工程目录找到package.appxmanifest,打开它. 2.在应用程序栏,通知选项,选择徽章和图块 ...

  7. 【cs229-Lecture13】高斯混合模型

    本节内容: 1.混合高斯模型: 2.将混合高斯模型应用到混合贝叶斯模型:(应用:文本聚类) 3.结合EM算法,讨论因子分析算法: 4.高斯分布的有用性质. 混合高斯模型 将一般化的EM算法流程(下载笔 ...

  8. HTML5 css3 阴影效果

    阴影效果曾让 Web 设计师既爱又恨,现在,有了 CSS3,你不再需要 Photoshop,已经有网站在使用这个功能了,如 24 Ways website. -webkit-box-shadow: 1 ...

  9. jQuery的回调管理机制

    // 对option的一个缓存,避免每次都需要createOptions,option是创建Callback对象时的传入的参数// 每个option被存入optionsCache中类似于{memory ...

  10. 题目1161:Repeater(规律输出图形)

    题目1161:Repeater 题目链接:http://ac.jobdu.com/problem.php?pid=1161 具体分析:https://github.com/zpfbuaa/JobduI ...