博客
关于我
Luogu4697 CEOI2011 Balloons 单调栈
阅读量:794 次
发布时间:2023-02-06

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

题意:给出$N$个气球,从左往右给出它们的$x_i$与$r_i$。现在从左往右给它们充气,每一个气球在充气的过程中始终在$x_i$点与地面相切,且最大半径为$r_i$。如果在充气的过程中气球与前面的某一个气球相切,则停止充气。问最后每个气球的半径。$N \leq 2 \times 10^5,x_i,r_i \leq 10^9$,保证$x_i$单调递增。


 首先可以计算得如果某一个气球$i$与前面的气球$j$相切时气球$i$的半径大小为$\frac{(x_i - x_j) ^ 2}{4r_j}$

然后我们可以手玩发现一个降低复杂度的方法:如果当前的气球的半径比之前的某些气球半径要大,这些气球是不会产生贡献的,而在某一次充气过程中,如果现在充气的最大值比某一个球的半径要小,那么其前面的在当前气球上也不可能产生贡献。所以我们可以维护一个$x$递增,$r$递减的单调栈来做决策,这样复杂度就降为$O(n)$了。

1 #include
2 #define ld long double 3 using namespace std; 4 5 const int MAXN = 200010; 6 int Stack[MAXN] , x[MAXN] , R[MAXN]; 7 ld r[MAXN]; 8 9 int main(){10 int N , hd = 0;11 cin >> N;12 for(int i = 1 ; i <= N ; i++){13 cin >> x[i] >> R[i];14 ld minN = R[i];15 while(hd){16 minN = min(minN , (x[i] - x[Stack[hd]]) / r[Stack[hd]] * (x[i] - x[Stack[hd]]) / 4);17 if(minN > r[Stack[hd]])18 hd--;19 else20 break;21 }22 cout << fixed << setprecision(5) << (r[i] = minN) << endl;23 Stack[++hd] = i;24 }25 return 0;26 }

转载于:https://www.cnblogs.com/Itst/p/9846693.html

你可能感兴趣的文章
Log4j.xml和Log4j2.xml的简单认识 - log4j2/log4j的区别
查看>>
log4j1/log4j2中category的配置以及log的输出位置(windows和linux通用的log输出位置)...
查看>>
Log4j2 中format增加自定义的参数
查看>>
Log4j2 消停了,Logback 开始塌房了?
查看>>
Log4j2 消停了,Logback 开始塌房了?
查看>>
Log4j2滚动策略深度解析:保持日志轻量高效
查看>>
Log4j使用总结
查看>>
Log4j使用配置总结
查看>>
log4j分离日志输出 自定义过滤 自定义日志文件
查看>>
Log4j日志级别
查看>>
Log4j日志级别 转
查看>>
log4j日志输出格式
查看>>
log4j日志输出格式一览
查看>>
log4j框架搭建
查看>>
Log4j漏洞?一行代码都不改就能永久修复?
查看>>
Log4J的配置
查看>>
log4j的配置说明
查看>>
log4j补充
查看>>
log4j记录日志
查看>>
Log4j输出到控制台成功,写入文件失败 - Log4j和commons log的整合
查看>>