当前位置: 首页 > news >正文

[Poi2011]Lightning Conductor题解

P3515 [POI 2011] Lightning Conductor

题目描述

逐渐变化的气候迫使 Byteburg 当局建造一个巨大的避雷针,以保护城市内的所有建筑物。

这些建筑物沿着一条街道排成一行,编号从1 11n nn

建筑物和避雷针的高度是非负整数。

Byteburg 的资金有限,只能建造一个避雷针。

而且,正如你所料,避雷针越高,成本越高。

位于建筑物i ii(高度为h i h_ihi)屋顶上的高度为k kk的避雷针可以保护建筑物j jj(高度为h j h_jhj),如果满足以下不等式:

k + h i ≥ h j + ∣ i − j ∣ k + h_i \geq h_j + \sqrt{|i-j|}k+hihj+ij

其中∣ i − j ∣ |i - j|ij表示i iij jj之间的绝对差值。

Byteburg 的市长 Byteasar 请求你的帮助。

编写一个程序,对于每个建筑物i ii,确定如果将避雷针放在建筑物i ii上,能够保护所有建筑物的避雷针的最小高度。

输入格式

标准输入的第一行有一个整数n nn(1 ≤ n ≤ 500 , 000 1 \leq n \leq 500,0001n500,000),表示 Byteburg 中的建筑物数量。

接下来的n nn行中的每一行包含一个整数h i h_ihi(0 ≤ h i ≤ 1 , 000 , 000 0 \leq h_i \leq 1,000,0000hi1,000,000),表示第i ii个建筑物的高度。

输出格式

你的程序应输出恰好n nn行到标准输出。

i ii行应给出一个非负整数k i k_iki,表示第i ii个建筑物上避雷针的最小高度。

输入输出样例 #1

输入 #1

6 5 3 2 4 2 4

输出 #1

2 3 5 3 5 4

说明/提示

题面翻译由 ChatGPT-4o 提供。

思路

动态规划
决策单调性

代码见下

#include<bits/stdc++.h>usingnamespacestd;longlongn;doublea[500005],f[500005],sq[500005];voidabc(longlongl,longlongr,longlongx,longlongy){if(l>=r+1){return;}longlongmid=(l+r)/2,p;doublema=0.00;for(inti=x;i<=min(mid,y);i++){if(a[i]+sq[mid-i]>ma){ma=a[i]+sq[mid-i];p=i;}}if(ma>f[mid]){f[mid]=ma;}abc(l,mid-1,x,p);abc(mid+1,r,p,y);return;}intmain(){cin>>n;for(inti=1;i<=n;i++){cin>>a[i];sq[i]=sqrt(i);}abc(1,n,1,n);for(inti=1;i<=n/2;i++){swap(a[i],a[n-i+1]);swap(f[i],f[n-i+1]);}abc(1,n,1,n);for(inti=1;i<=n/2;i++){swap(a[i],a[n-i+1]);swap(f[i],f[n-i+1]);}for(inti=1;i<=n;i++){cout<<(longlong)ceil(f[i])-(longlong)a[i]<<endl;}return0;}
http://www.cnnetsun.cn/news/138230.html

相关文章:

  • 一文读懂大模型:收藏级教程,助你从入门到精通
  • Nginx云计算大数据——安装AND版本升级(普通升级+平滑升级+失败回滚)
  • GPT-5.2 实测数据流出:逻辑推理性能翻倍,大模型“幻觉”真的被终结了吗?
  • SQL SERVER——通过计划任务方式每月对配置数据、审计数据等进行备份
  • 前端——跨平台桌面应用开发实践
  • OpenAI 的反击!GPT-5.2 强行拉开代差,Gemini 3 和 Claude 4 还有机会吗?
  • 零售打工人加薪难?靠这张证,我在激烈竞争里站稳了脚跟
  • 基于springboot的多媒体素材库的开发与应用毕业论文+PPT(附源代码+演示视频)
  • 从离线语音到多模态智能体四博智联 AI 硬件整体解决方案全景解析
  • 我发现跨医院联合训练让诊断准确率飙升后来才知道是横向联邦学习在数据孤岛中的绝招
  • 性能压测工具:wrk
  • 论文引用标注工具排名2025:6大平台+自动规范推荐
  • Kotaemon AWS EC2部署实例:国际业务首选
  • 实在没货,简历(软件测试)咋写?
  • 网约车服务端线上流量巡检与测试验收技术
  • 公考日记7
  • 火电一次调频、自抗扰调频及群智能算法智能调频在MATLAB/Simulink中的应用
  • 科研实验室温湿度监控新范式:以太网 POE 技术全场景解决方案
  • RV1126 NO.57:ROCKX+RV1126人脸识别推流项目之读取人脸图片并把特征值保存到sqlite3数据库
  • 探索SAR ADC:45nm工艺下的高速高精度设计
  • 【小增长技术团队东哥分享】Electron vs Electron-Vite vs Electron-Egg:桌面端开发到底该选谁?
  • 测试价值的量化评估:从成本中心到价值证明的路径探索
  • 测试领导力:在敏捷洪流中筑造质量堤坝
  • C++常用设计模式
  • Spring Boot 自动配置深度解析:原理、实战与源码追踪
  • 无代码解决方案:破解企业数字化转型效率困局
  • SAM (Segment Anything Model):万物皆可分割-k学长深度学习专栏
  • Mysql 报错 “Public Key Retrieval is not allowed”
  • 熊市中最适用的公式==底部建仓
  • 100G双光口网卡技术解析:Intel E810-CAM2方案的性能与应用突破