LOJ 6041 事情的相似度 题解

news/2024/10/7 9:17:02/文章来源:https://www.cnblogs.com/laijinyi/p/18449761

Statement

先把串 reverse,多次给 \(l,r\),求

\[ \max_{l\le i<j\le r}\{\text{LCP}(i,j)\} \]

Solution

  • \(\text{sqrtlog}\sim\text{sqrt}\):莫队 + 线段树 / 树状数组 / set,用 SA 做
  • \(nm/\omega\):bitset 乱搞
  • \(\log^2\):SAM + LCT + BIT

在 parent 树上,LCP 等于 LCA 的 len

离线,每次加入右端点就 access 一下,过程中对产生的 LCA 关系进行更新.

  • 还有一种做法是在 parent 树上 set 启发式合并,然后二维数点

Code

一遍写完一遍过!太牛了。

#include <bits/stdc++.h>
using namespace std;
#define rep(i, j, k) for (int i = (j); i <= (k); ++i)
#define reo(i, j, k) for (int i = (j); i >= (k); --i)
typedef long long ll;
const int N = 2e5 + 10;
vector<pair<int, int>> Queries[N];
int n, m;
string s;struct BIT {int len, mx[N];BIT(int _len = 0) {len = _len, memset(mx, 0, sizeof(mx));}void Upd(int x, int v) {for (; x <= len; x += x & -x) mx[x] = max(mx[x], v);}int Qry(int x) {int res = 0;for (; x; x -= x & -x) res = max(res, mx[x]);return res;}
} bit;namespace SAM {int sz, cur, last, len[N], link[N], nxt[N][2];void init() {link[0] = -1;}void extend(int ch) {cur = ++sz, len[cur] = len[last] + 1;int p = last;for (; ~p; p = link[p])if (!nxt[p][ch]) nxt[p][ch] = cur;else break;if (!~p) {link[cur] = 0;} else {int q = nxt[p][ch];if (len[p] + 1 == len[q]) {link[cur] = q;} else {int copy = ++sz;link[copy] = link[q], link[q] = link[cur] = copy, len[copy] = len[p] + 1;nxt[copy][0] = nxt[q][0], nxt[copy][1] = nxt[q][1];for (; ~p; p = link[p])if (nxt[p][ch] == q) nxt[p][ch] = copy;else break;}}last = cur;}void Build() {init();for (auto ch : s) extend(ch - 48);bit = BIT(n);}
}int now;namespace LinkCutTree {int fa[N], ch[N][2], tag[N], val[N];#define get(u) (u == ch[fa[u]][1])#define nrt(u) (u == ch[fa[u]][0] || u == ch[fa[u]][1])void cov(int u, int v) {if (u) tag[u] = val[u] = v;}void down(int u) {if (tag[u]) cov(ch[u][0], tag[u]), cov(ch[u][1], tag[u]), tag[u] = 0;}void Down(int u) {if (nrt(u)) Down(fa[u]);down(u);}void rot(int u) {int f = fa[u], g = fa[f], k = get(u);if (nrt(f)) ch[g][get(f)] = u;ch[f][k] = ch[u][!k];if (ch[u][!k]) fa[ch[u][!k]] = f;ch[u][!k] = f, fa[f] = u, fa[u] = g;}void splay(int u) {for (Down(u); nrt(u); rot(u)) if (nrt(fa[u])) rot(get(u) == get(fa[u]) ? fa[u] : u);}void access(int u) {int v = 0;for (; u; v = u, u = fa[u]) {splay(u);if (v) {bit.Upd(n - val[u] + 1, SAM::len[u - 1]);}ch[u][1] = v;}cov(v, now);}#undef get#undef nrt
}
int ans[N];int main() {ios::sync_with_stdio(false), cin.tie(nullptr);cin >> n >> m >> s;rep(i, 1, m) {int l, r;cin >> l >> r;Queries[r].push_back(make_pair(l, i));}SAM::Build();rep(i, 1, SAM::sz) LinkCutTree::fa[i + 1] = SAM::link[i] + 1;int pos = 0;rep(i, 1, n) {now = i;pos = SAM::nxt[pos][s[i - 1] - 48];LinkCutTree::access(pos + 1);for (auto qry : Queries[i])ans[qry.second] = bit.Qry(n - qry.first + 1);}rep(i, 1, m) {cout << ans[i] << '\n';}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/809321.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

java之使用CompletableFuture入门2

Java 17 -序章 本文介绍用过的 allOf、anyOf 函数的用法。allOf 函数原型两点: 1、没有返回值。 2、参数 cfs 中 任何一个 都不能是 null。anyOf 函数原型两点: 1、有返回值,为 Object。 2、参数 cfs 中 任何一个 都不能是 null。allOf 测试意图: 多个任务正常执行。ben发布…

VMware Aria Operations for Logs 8.18 发布,新增功能概览

VMware Aria Operations for Logs 8.18 发布,新增功能概览VMware Aria Operations for Logs 8.18 - 集中式日志管理 请访问原文链接:https://sysin.org/blog/vmware-aria-operations-for-logs/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org集中式日志管理 V…

VMware Aria Operations for Networks 6.13 发布,新增功能概览

VMware Aria Operations for Networks 6.13 发布,新增功能概览VMware Aria Operations for Networks 6.13 - 网络和应用监控工具 请访问原文链接:https://sysin.org/blog/vmware-aria-operations-for-networks/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org…

读数据工程之道:设计和构建健壮的数据系统01数据工程概述

数据工程概述1. 数据工程 1.1. 自从公司开始使用数据做事,数据工程就以某种形式存在了1.1.1. 预测性分析、描述性分析和报告1.2. 数据工程师获取数据、存储数据,并准备数据供数据科学家、分析师和其他人使用 1.3. 数据工程是系统和流程的开发、实施和维护,这些系统和流程接收…

安装socks5的一次尝试

1. 下载并自动配置socks5sudo wget https://ap-guangzhou-1257892306.cos.ap-guangzhou.myqcloud.com/asi/httpsocks5.sh && sh httpsocks5.sh 执行下载脚本 wget —no-check-certificate https://raw.github.com/Lozy/danted/master/install.sh -O install.sh执行安装…

形函数的构造7

形函数构造 构造单元1的一般近似函数 \(\overline{V(x)}^{(1)}\),由于该单元只有两个节点\(x_1\)和\(x_2\),我们选择包含两个参数\(\alpha_1\)和\(\alpha_2\)的近似方程 \[\overline{V(x)}^{(1)}=\alpha_1+\alpha_2\times x \]令试函数与\(V(x)\)在节点\(x_1\)和\(x_2\)处相等…

等参单元4

在自然坐标系中 , \(\xi_2=1\)和 \(\xi_2=1\),在物理坐标系中为 \(x_1\) 和\(x_2\),相应的节点位移为\(u_1\) 和\(u_2\) 。 在自然坐标系 下,单元形函数为 \[N_{1}(\xi)=\frac{1}{2}(1-\xi)\\N_{2}(\xi)=\frac{1}{2}(1+\xi) \] 利用形函数,在自然坐标系下单元内的任一点 \(…

二维或三维的分布积分方法(格林公式)7

二维或三维的分布积分(格林公式) 分布积分对下式积分 \[\int\int_{\Omega}\Phi\frac{\partial\Psi}{\partial x}\mathrm{d}x\mathrm{d}y \] 首先对变量\(x\)分布积分 \[\int\limits_{X_L}^{X_R}U\mathrm{d}V=(UV_{X=X_R}-UV_{X=X_L})-\int\limits_{X_L}^{X_R}V\mathrm{d}U \]…

流体力学8-3

第一章 1.1 流体的概念 任何固体材料都有一个强度极限,即使合外力和力矩都为零,它的内部也可能会存在着拉力、压力或者剪切力。当这些内应力超过了材料的强度极限时,固体就会被破坏,从而产生运动。微观上体现为断裂处的分子(或原子)之间的化学键被破坏,失去了相互的作用…

应力分析7

目录3.1 几个基本概念3.3 任意斜截面上的应力3.4 主应力及应力(张量)不变量3.5 最大、最小正应力和最大剪应力 3.1 几个基本概念 • 外力 外力指的是我们熟知的机械力、电磁力等,物体因外力作用而变形。作用于物体的外力可分为体积力和表面 力,它们分别简称为体力和面力。…

塑性力学本构模型基本框架7

目录一. 引言二. 塑性应变增量推导三. 弹塑性刚度矩阵推导四. 塑性模量理解五. 小结 一. 引言 弹塑性理论定义材料在荷载作用下的变形是弹性变形和塑性变形之和,其中研究塑性变形需要解决三个方面的问题: ①产生塑性变形的起点; ②产生塑性变形的方向; ③产生塑性变形的大小…