Luogu4697 CEOI2011 Balloons 单调栈

解决气球充气问题,通过维护一个单调栈实现O(n)复杂度算法,确保气球充气过程不相交。

传送门

题意:给出$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<bits/stdc++.h>
 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             else
20                 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

dnSpy是目前业界广泛使用的一款.NET程序的反编译工具,支持32位和64位系统环境。它允许用户查看和编辑.NET汇编和反编译代码,以及调试.NET程序。该工具通常用于程序开发者在维护和调试过程中分析程序代码,尤其在源代码丢失或者无法获取的情况下,dnSpy能提供很大的帮助。 V6.1.8版本的dnSpy是在此系列软件更新迭代中的一个具体版本号,代表着该软件所具备的功能与性能已经达到了一个相对稳定的水平,对于处理.NET程序具有较高的可用性和稳定性。两个版本,即32位的dnSpy-net-win32和64位的dnSpy-net-win64,确保了不同操作系统架构的用户都能使用dnSpy进行软件分析。 32位的系统架构相较于64位,由于其地址空间的限制,只能支持最多4GB的内存空间使用,这在处理大型项目时可能会出现不足。而64位的系统能够支持更大的内存空间,使得在处理大型项目时更为方便。随着计算机硬件的发展,64位系统已经成为了主流,因此64位的dnSpy也更加受开发者欢迎。 压缩包文件名“dnSpy-net-win64.7z”和“dnSpy-net-win32.7z”中的“.7z”表示该压缩包采用了7-Zip压缩格式,它是一种开源的文件压缩软件,以其高压缩比著称。在实际使用dnSpy时,用户需要下载对应架构的压缩包进行解压安装,以确保软件能够正确运行在用户的操作系统上。 dnSpy工具V6.1.8版本的发布,对于.NET程序员而言,无论是32位系统还是64位系统用户,都是一个提升工作效率的好工具。用户可以根据自己计算机的操作系统架构,选择合适的版本进行下载使用。而对于希望进行深度分析.NET程序的开发者来说,这个工具更是不可或缺的利器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值