【蓝桥杯集训·每日一题2025】 AcWing 5526. 平衡细菌 python

AcWing 5526. 平衡细菌

Week 3
3月4日

题目描述

农夫约翰有 N N N 块草地排成一行,其中草地 i i i 的细菌水平与健康草的细菌水平相差 a i a_i ai。

例如,如果 a i = − 3 a_i=−3 ai=−3,则草地 i i i 的细菌水平比正常水平低 3 3 3,需要额外添加恰好 3 3 3 个单位的细菌才能将其提高到被认为是健康的程度。

农夫约翰想要确保每一块草地都被修复至健康的细菌水平。

方便的是,他有两种品牌的农药可以喷洒在他的田地里,一种可以添加细菌,另一种可以去除细菌。

当农夫约翰喷洒任一类型的农药时,他站在草地 N N N(最右边的草地)并为他的喷雾器选择功率等级 L L L( 1 ≤ L ≤ N 1 \le L \le N 1≤L≤N)。

喷雾器对靠近农夫约翰的草地效果最大,随着距离增加效果逐渐减弱。

如果农夫约翰选择添加细菌的农药,则 L L L 单位的细菌将被添加至草地 N N N, L − 1 L−1 L−1 单位添加至草地 N − 1 N−1 N−1, L − 2 L−2 L−2 单位添加至草地 N − 2 N−2 N−2,以此类推。

草地 1 ... N − L 1...N−L 1...N−L 不会得到任何细菌,因为喷雾器设置的功率不足以到达它们。

类似地,如果农夫约翰选择去除细菌的农药,则 L L L 单位的细菌将被从草地 N N N 去除, L − 1 L−1 L−1 单位被从草地 N − 1 N−1 N−1 去除,以此类推。

同样,草地 1 ... N − L 1...N−L 1...N−L 将不受影响。

求农夫约翰使用喷雾器的最少次数,使得每块草地都具有健康草的推荐细菌值。

输入保证答案不超过 1 0 9 10^9 109。

输入格式

输入的第一行包含 N N N。

第二行包含 N N N 个整数 a 1 ... a N a_1...a_N a1...aN,为每块草地的初始细菌水平。

输出格式

输出一个整数,为使每块草地都具有健康草的推荐的细菌值所需使用喷雾器的最少次数。

数据范围

1 ≤ N ≤ 2 × 1 0 5 1 \le N \le 2 \times 10^5 1≤N≤2×105,
− 1 0 15 ≤ a i ≤ 1 0 15 -10^{15} \le a_i \le 10^{15} −1015≤ai≤1015

输入样例1:
复制代码
2
-1 3
输出样例1:
复制代码
6
样例1解释

使用去除细菌的农药,功率等级为 1 1 1,使用五次。

然后使用添加细菌的农药,功率等级为 2 2 2,使用一次。

输入样例2:
复制代码
5
1 3 -2 -7 5
输出样例2:
复制代码
26

等差数列差分


AC_code

python 复制代码
n = int(input())  
a = list(map(int, input().split()))  
  
diff = [0] * n  
diff[0] = a[0]  
for i in range(1, n):  
    diff[i] = a[i] - a[i - 1]  
  
diff2 = [0] * n  
diff2[0] = diff[0]  
for i in range(1, n):  
    diff2[i] = diff[i] - diff[i - 1]  
  
ans = 0  
for i in range(n):  
    ans += abs(diff2[i])  
print(ans)

END
如果有更多问题或需要进一步的帮助,可以在评论区留言讨论哦!
如果喜欢的话,请给博主点个关注 谢谢

相关推荐
闲人编程32 分钟前
构建一个短链接生成器服务(FastAPI + SQLite)
jvm·python·sqlite·fastapi·生成器·短链接·caodecapsule
杰瑞哥哥1 小时前
标准 Python 项目结构
开发语言·python
不当菜鸡的程序媛1 小时前
Flow Matching|什么是“预测速度场 vt=ε−x”?
人工智能·算法·机器学习
西部森林牧歌1 小时前
Arbess零基础学习 - 使用Arbess+GitLab实现Python项目构建/主机部署
python·ci/cd·gitlab·tiklab devops
Jay_Franklin1 小时前
Python中使用sqlite3模块和panel完成SQLite数据库中PDF的写入和读取
数据库·笔记·python·pycharm·sqlite·pdf·py
热爱编程的小白白2 小时前
【Playwright自动化】安装和使用
开发语言·python
听风吟丶2 小时前
Java NIO 深度解析:从 BIO 到 NIO 的演进与实战
开发语言·python
sali-tec2 小时前
C# 基于halcon的视觉工作流-章58-输出点云图
开发语言·人工智能·算法·计算机视觉·c#
_OP_CHEN2 小时前
算法基础篇:(四)基础算法之前缀和
c++·算法·前缀和·蓝桥杯·acm·icpc·算法竞赛
_OP_CHEN2 小时前
算法基础篇:(五)基础算法之差分——以“空间”换“时间”
c++·算法·acm·icpc·算法竞赛·差分算法·差分与前缀和