news 2026/6/8 18:45:55

[Poi2011]Lightning Conductor题解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
[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;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/6 23:35:19

【MongoDB实战】8.2 简易商品管理系统-核心功能实现

文章目录 简易商品管理系统(MongoDB + Flask 实现) 一、环境准备 1. 安装依赖 2. 配置文件(.env) 二、核心代码实现 整体结构 三、核心功能说明 1. 数据层(ProductDB) 2. 业务层(ProductService) 3. 接口层(Flask 路由) 四、测试示例 1. 启动服务 2. 接口测试(curl …

作者头像 李华
网站建设 2026/6/8 13:09:12

jQuery EasyUI 树形菜单 - 创建基础树形网格

jQuery EasyUI 树形网格&#xff08;TreeGrid&#xff09; - 创建基础树形网格 jQuery EasyUI 的 TreeGrid&#xff08;树形网格&#xff09;是基于 DataGrid 扩展的组件&#xff0c;用于显示带有层级关系的表格数据。它结合了树视图&#xff08;Tree&#xff09;和可编辑网格…

作者头像 李华
网站建设 2026/6/7 2:14:37

jQuery EasyUI 树形菜单 - 树形网格添加分页

jQuery EasyUI 树形网格&#xff08;TreeGrid&#xff09; - 添加分页 jQuery EasyUI 的 TreeGrid 继承自 DataGrid&#xff0c;因此支持 pagination: true 属性来启用分页功能。但由于 TreeGrid 是层级结构&#xff0c;分页通常只针对顶级根节点进行&#xff08;子节点通过动…

作者头像 李华
网站建设 2026/6/7 20:51:20

Kotaemon如何应对文化差异?本地化适配策略分析

Kotaemon如何应对文化差异&#xff1f;本地化适配策略分析 在智能客服系统走向全球的今天&#xff0c;一个看似简单的用户提问——“我能不能退货&#xff1f;”——背后可能隐藏着巨大的文化鸿沟。在日本&#xff0c;这或许是一句含蓄的情绪表达&#xff1b;在德国&#xff0c…

作者头像 李华
网站建设 2026/6/8 3:09:16

IM即时通讯系统:安全可控、功能全面的社交解决方案全解析

在数字化社交时代&#xff0c;即时通讯&#xff08;IM&#xff09;系统已成为社交平台的核心基础设施。本文将深入解析开源IM系统的核心优势与功能亮点&#xff0c;为开发者提供一套安全可控、功能全面的社交解决方案。一、核心优势&#xff1a;安全与性能的双重保障1. 独立数据…

作者头像 李华