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

2025/10/27~2025/11/2 做题笔记 - sb

2025/10/27

第一代图灵机

一样的套路,考虑每一个右端点对应的最左边可以到哪里,显然是最小的 \(j\) 使得 \(\max\limits_{j \le k \le i}pre_k = j - 1\)。考虑线段树维护一个区间内的最大的答案和最大的 \(pre_i\),但是发现当 \(pushup\) 的时候不好判断右区间对整个区间的贡献,所以需要维护一个区间中右半边区间对答案的贡献。不过最后可以发现一个区间内最大的答案也没什么用,没办法只通过它算出一个区间内指定一个最小 \(pre\) 的答案,还是只能用 \(pushup\) 算出来

Code
#include <iostream>
#include <set>using namespace std;
using ll = long long;
using pll = pair<ll, ll>;const int kN = 2e5 + 1;int n, m, q, c[kN];
set<int> s[kN];
ll a[kN];
struct Tr {int mx;ll val;
} tr[kN * 4];ll Pushup(int mx, int x, int l, int r) {if (l == r)return a[l] - a[max(mx, tr[x].mx)];int m = (l + r) / 2;if (mx > tr[x * 2].mx)return max(a[m] - a[mx], Pushup(mx, x * 2 + 1, m + 1, r));return max(tr[x].val, Pushup(mx, x * 2, l, m));
}
void Update(int p, int k, int x = 1, int l = 1, int r = n) {if (l == r)return tr[x].mx = k, void();int m = (l + r) / 2;if (p <= m)Update(p, k, x * 2, l, m);elseUpdate(p, k, x * 2 + 1, m + 1, r);tr[x].mx = max(tr[x * 2].mx, tr[x * 2 + 1].mx), tr[x].val = Pushup(tr[x * 2].mx, x * 2 + 1, m + 1, r);
}
ll Query(int mx, int nl, int nr, int x = 1, int l = 1, int r = n) {if (nl <= l && r <= nr)return Pushup(mx, x, l, r);int m = (l + r) / 2;ll res = 0;if (nl <= m)res = Query(mx, nl, nr, x * 2, l, m);if (nr > m)res = max(res, Query(max(mx, tr[x * 2].mx), nl, nr, x * 2 + 1, m + 1, r));return res;
}int main() {
#ifndef ONLINE_JUDGEfreopen("in", "r", stdin);freopen("out", "w", stdout);
#endifcin.tie(0)->sync_with_stdio(0);cin >> n >> m >> q;for (int i = 1; i <= m; i++)s[i].insert(0);for (int i = 1; i <= n; i++)cin >> a[i], a[i] += a[i - 1];for (int i = 1; i <= n; i++) {cin >> c[i];Update(i, *s[c[i]].rbegin()), s[c[i]].insert(i);}for (int op, l, r; q--;) {cin >> op >> l >> r;if (op - 1) {auto it = s[c[l]].find(l);if (next(it) != s[c[l]].end())Update(*next(it), *prev(it));s[c[l]].erase(l), c[l] = r;it = s[c[l]].lower_bound(l);if (it != s[c[l]].end())Update(*it, l);Update(l, *prev(it)), s[c[l]].insert(l);} else {cout << Query(l - 1, l, r) << '\n';}}return 0;
}
http://www.gsyq.cn/news/31939.html

相关文章:

  • 完整教程:LinuxC++——etcd分布式键值存储系统入门
  • 我从哪里起飞 从哪里降落 多少不能原谅的错 却不能重来过
  • MATLAB 时间序列小波周期分析
  • 本地运行nginx服务,模拟线上环境访问项目
  • 基于Redis海量数据场景分布式ID生成实践
  • 分享精选文章合集 - 2025-10-27
  • 2025 年搅拌器搅拌设备,侧入式搅拌设备,斜插式揽拌设备,卧式搅拌设备厂家最新推荐,聚焦资质、案例、售后的五家企业深度解读
  • 2025 年环保搅拌设备,搅拌装置设备,框式搅拌设备厂家最新推荐,实力品牌深度解析采购无忧之选!
  • 2025质量可靠的义乌刺绣工厂推荐榜
  • 2025 年液压旋转接头,高温蒸汽旋转接头,通水旋转接头厂家最新推荐,精准检测与稳定性能深度解析
  • Linux基本命令篇 —— date命令
  • nef怎么转换成jpg格式你还不会?分享4个实用技巧
  • 2025年上海家电展会展台搭建服务商权威推荐榜单:展台搭建会展服务/会展展台装修设计/展台设计装修源头公司精选
  • macro出pin
  • 2025 年定制矿车,大型矿车,固定式矿车厂家最新推荐,产能、专利、环保三维数据透视
  • 2025 年 10 月翻斗式矿车,侧翻矿车,1 吨矿车,运输矿车厂家最新推荐,产能、专利、环保三维数据透视
  • 2025 年江苏电缆附件,热缩电缆附件,冷缩电缆附件,预制电缆附件厂家最新推荐,产能、专利、环保三维数据透视
  • 9 GHz 巴伦做到 22 mm,HT-BAL-0006SMG 简单上机测一波
  • 低代码开发便捷的技术深度解析
  • 2025年打篮球隐形眼镜生产商权威推荐榜单:周抛隐形眼镜/rgp隐形眼镜/硬性隐形眼镜源头厂家精选
  • 2025年浅拾兰花双萃致臻精华油:从成分与技术维度深度解析其护肤功效
  • DGX Spark(Ubuntu24.04)下编译安装OpenCV
  • 2025年移动车载变电站厂家最新推荐榜:陕西四方华能凭硬实力成优选
  • 2025年最新可靠的钣金加工厂家找哪家,知名的钣金加工口碑推荐榜睿意达专注产品质量
  • Visual Studio Code使用Python 3.6.8
  • vscode 添加代码片段中的预置变量总结
  • 251027
  • 2025年10月重庆装饰装修公司推荐排行榜:十大企业综合评测与选购指南
  • 未来工业AI发展的三个必然阶段
  • 大数据分析基础及应用案例:第五周学习报告——逻辑回归、决策树