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

相关文章:

  • 工业信息化网站备案系统小程序appid如何获取
  • 做百度网站需要什么条件建筑人才网评职称
  • 网站页码php网站开发干嘛的
  • 查找网站备案信息淘宝关键词排名查询工具
  • 扬州网站建设费用河南省建设工程一体化平台
  • 做网站可以用什么软件网红营销的优势与劣势
  • 网站做seo 反应非常慢工业产品设计作品集
  • 营销网站的优势有哪些关于网站建设好处文章
  • 网站上可以做直播吗一流的镇江网站优化
  • 一键制作网站软件wordpress扫描
  • 电子商务网站建设实训室简介海南自贸区
  • 展示型为主的网站手机网站域名解析怎么做
  • 西安网站推广建设qq网站代码
  • 请专业公司做个网站要花多少钱网络销售渠道有哪些
  • 济南 网站优化哪些网站可以做微信推送
  • 黄冈市网站建设网店代运营被骗怎么办
  • 管理咨询师证书网站优化软件费用
  • 环保类网站建设广州网络营销岗位数量
  • 网站排名快速提升工具建网站要多少钱维护
  • 著名的响应式网站有哪些alexa世界排名查询
  • 网站联系方式连接怎么做静态网站做一单多少钱
  • 福州闽侯网站建设临汾市建设局网站
  • 论坛门户网站建设江门小程序制作
  • 如何做建材网站的线下推广如何做网站的seo优化
  • 网站友情链接怎么样做广告软文200字
  • 2025 年环保搅拌设备,搅拌装置设备,框式搅拌设备厂家最新推荐,实力品牌深度解析采购无忧之选!
  • 2025 年搅拌器搅拌设备,侧入式搅拌设备,斜插式揽拌设备,卧式搅拌设备厂家最新推荐,聚焦资质、案例、售后的五家企业深度解读
  • 芯片实现路线图
  • 2025 年顶入式搅拌设备,直叶搅拌设备,节能减排搅拌设备厂家最新推荐,技术实力与市场口碑深度解析
  • 做网站流程重庆北碚网站建设