当前位置: 首页 > 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.jsqmd.com/news/23775/

相关文章:

  • echart - f
  • 完整教程:LinuxC++——etcd分布式键值存储系统入门
  • 基于MATLAB的光学CCD全息成像仿真程序实现
  • el-date-picker样式修改
  • 我从哪里起飞 从哪里降落 多少不能原谅的错 却不能重来过
  • unity管理器设计:Manager of Managers
  • iview table 排序 columns 里面写 sortable: custom 不要写 sortable: true 不然会进行二次内部排序序号等 字段。
  • 决策不再凭感觉!Tita用数据驱动销售与交付的一体化协同
  • 浅谈 Agent 开发工具链演进历程
  • 为IvorySQL增添PACKAGE语法帮助
  • MATLAB 时间序列小波周期分析
  • # 情绪日历应用(python AI项目)
  • 读《程序员修炼之道:从小工到专家》
  • 本地运行nginx服务,模拟线上环境访问项目
  • git提交远程项目步骤
  • 基于Redis海量数据场景分布式ID生成实践
  • 电梯调度算法结对编程作业
  • 【完结22章】从0到1,LangChain+RAG全链路实战AI知识库
  • 分享精选文章合集 - 2025-10-27
  • 20232416 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 2025 年搅拌器搅拌设备,侧入式搅拌设备,斜插式揽拌设备,卧式搅拌设备厂家最新推荐,聚焦资质、案例、售后的五家企业深度解读
  • 芯片实现路线图
  • 2025 年环保搅拌设备,搅拌装置设备,框式搅拌设备厂家最新推荐,实力品牌深度解析采购无忧之选!
  • 2025 年顶入式搅拌设备,直叶搅拌设备,节能减排搅拌设备厂家最新推荐,技术实力与市场口碑深度解析
  • 10.27总结
  • BongoCat日志搜索程序:正则表达式与高级筛选
  • WPF 自定义控件库
  • 2025质量可靠的义乌刺绣工厂推荐榜
  • c# 使用 jwt
  • 2025义乌做刺绣的厂家推荐榜单