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

【最优清零方案——贪心+滑动窗口+线段树】

题目

代码

#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const int N = 1e6 + 10;
int a[N];
struct node
{int l, r;int m, p, lazy;
} tr[4 * N];
void pushup(node &u, node &l, node &r)
{if (l.m == r.m){u.m = l.m;u.p = max(l.p, r.p);}else if (l.m < r.m){u.m = l.m;u.p = l.p;}else{u.m = r.m;u.p = r.p;}
}
void pushup(int u)
{pushup(tr[u], tr[u << 1], tr[u << 1 | 1]);
}
void pushdown(node &u, node &l, node &r)
{if (u.lazy){l.m = max(l.m + u.lazy, 0);r.m = max(r.m + u.lazy, 0);l.lazy += u.lazy;r.lazy += u.lazy;u.lazy = 0;}
}
void pushdown(int u)
{pushdown(tr[u], tr[u << 1], tr[u << 1 | 1]);
}
void build(int u, int l, int r)
{if (l == r)tr[u] = {l, r, a[l], l};else{tr[u] = {l, r};int mid = l + r >> 1;build(u << 1, l, mid), build(u << 1 | 1, mid + 1, r);pushup(u);}
}
void modify(int u, int l, int r, int d)
{if (l <= tr[u].l && tr[u].r <= r){tr[u].lazy += d;tr[u].m = max(tr[u].m + d, 0);return;}pushdown(u);int mid = tr[u].l + tr[u].r >> 1;if (l <= mid)modify(u << 1, l, r, d);if (r > mid)modify(u << 1 | 1, l, r, d);pushup(u);
}
node query(int u, int l, int r)
{if (l <= tr[u].l && tr[u].r <= r)return tr[u];pushdown(u);int mid = tr[u].l + tr[u].r >> 1;if (r <= mid)return query(u << 1, l, r);else if (l > mid)return query(u << 1 | 1, l, r);else{auto left = query(u << 1, l, r);auto right = query(u << 1 | 1, l, r);node ans;pushup(ans, left, right);return ans;}
}
int main()
{int n, k;cin >> n >> k;ll sum = 0;for (int i = 1; i <= n; i++)cin >> a[i], sum += a[i];build(1, 1, n);int l = 1, r;ll cnt = 0;while (r = l + k - 1, r <= n){auto u = query(1, l, r);int minn = u.m;cnt += minn;modify(1, l, r, -minn);l = u.p + 1;}cout << sum - k * cnt + cnt;
}

http://www.lryc.cn/news/490142.html

相关文章:

  • 一个点绕任意点旋转后的点的坐标
  • 大数据面试题每日练习--HDFS是如何工作的?
  • Python的3D可视化库 - vedo (2)visual子模块 基本可视化行为
  • Java AIO(NIO.2)
  • Flink 常用问题及常用配置(有用)
  • RocketMQ: 消息过滤,通信组件,服务发现
  • linux ubuntu的脚本知
  • HTTP有哪些风险?是怎么解决的?
  • 3.12MayBeSomeLinearAlgebra
  • 学习日志015--python单链表
  • 如何在Windows右键新建菜单中添加自定义项
  • Spring Boot 3.0废弃了JavaEE,改用了Jakarta EE
  • pdf文档动态插入文字水印,45度角,旋转倾斜,位于文档中央,多行水印可插入中文
  • [ 渗透测试面试篇-2 ] 针对大规模资产的攻击思路
  • 深入解析 Web 应用中的 CHIPS(Partitioned Cookie Attribute)
  • 从搭建uni-app+vue3工程开始
  • 归并排序与逆序对问题(C语言版)
  • 网络爬虫总结与未来方向
  • C++ 核心数据结构:Stack 与 Queue 类深度解析
  • Python枚举类详解:用enum模块高效管理常量数据
  • 企业OA管理系统:Spring Boot技术深度探索
  • 汽车免拆诊断案例 | 2012款路虎揽胜运动版柴油车加速无力
  • uniapp接入高德地图
  • (UI自动化测试)web自动化测试
  • 【es6进阶】如何使用Proxy实现自己的观察者模式
  • 住宅IP怎么在指纹浏览器设置运营矩阵账号
  • 表格数据处理中大语言模型的微调优化策略研究
  • CentOS7 如何查看kafka topic中的数据
  • VRRP实现出口网关设备冗余备份
  • 超详细:Redis分布式锁