题解 ICPC 2019 SH 区域赛 F 树上简单问题

CF的Gym里没找着 牛客的题目链接

首先这个题多测非常SB, 每次都要清空, 需要特别注意.

树剖应该都会吧, Defad之后也会发博客讲解, 这里主要讲一下线段树维护区间加区间乘区间赋值区间立方和.

区间加

首先, 想一下我们要维护什么.

我们推一下式子, 看看式子中有哪些是要维护的, 哪些是要修改的.

Defad曰, "岂曰线段树题非好题乎, 岂曰推式子非神题乎, 岂曰多测出题人不满门抄斩乎".

\(
(v + k)^{3}
\newline
= (v + k)(v + k)^{2}
\newline
= (v + k)(v^{2} + k^{2} + 2vk)
\newline
= v^{3} + k^{3} + 3v^{2}k + 3vk^{2}
\)

Defad在VP时被二项式定理忘记了, 所以这里直接硬推的.

在这个式子中, 我们用到了区间立方和与区间平方和与区间和, 区间和就不用推了, 推一下区间平方和的修改.

\(
(v + k)^{2}
\newline
= v^{2} + k^{2} + 2vk
\)

我们推的是单点修改的式子, 区间修改只需在纯 \(k\) 的项上乘 \(r - l + 1\) 即可.

为什么只有纯 \(k\) 的项需要乘区间长度? 因为我们在维护 \(v\) 时已经有区间长度了, 所以只有纯 \(k\) 项需要.

区间乘

区间乘推式子其实比区间加好推, 分别乘上 \(k\) 即可.

\((vk)^{3} = v^{3}k^{3}\)

\((vk)^{2} = v^{2}k^{2}\)

\(vk = vk\)

区间赋值

区间赋值其实很好实现, 这个不需要推式子, 就是想一下, 区间乘 \(0\) 然后区间加 \(k\) 实际上就相当于区间赋值了, Defad觉得这个挺重要的建议记一下.

代码

树剖就先不给代码了, 给一下线段树的 update 和传递标记, 这里用的是动态开点线段树.

题目要求取模.

inline
void pushup(int x) {
t[x].val1 = (t[t[x].ls].val1 + t[t[x].rs].val1) % Mod;
t[x].val2 = (t[t[x].ls].val2 + t[t[x].rs].val2) % Mod;
t[x].val3 = (t[t[x].ls].val3 + t[t[x].rs].val3) % Mod;
}
inline // 这个函数是结点加 f 乘 g 同时做了
void addmul(int *x, int l, int r, ll f, ll g) {
if (*x == 0) *x = ++cntt; // x 没有被修改过就是空结点
if (g ^ 1LL) { // 先乘, 如果乘 1 就不用乘了
ll g2 = g * g % Mod, g3 = g2 * g % Mod;
// 修改立方和
t[*x].val3 = t[*x].val3 * g3 % Mod;
// 修改平方和
t[*x].val2 = t[*x].val2 * g2 % Mod;
// 修改和
t[*x].val1 = t[*x].val1 * g % Mod;
// 打加标记
t[*x].add = t[*x].add * g % Mod;
// 打乘标记
t[*x].mul = t[*x].mul * g % Mod;
}
if (f ^ 0LL) { // 后加, 如果加 0 也不用加
ll f2 = f * f % Mod, f3 = f2 * f % Mod;
// 修改立方和
t[*x].val3 = (t[*x].val3 + f3 * (r - l + 1) % Mod) % Mod;
t[*x].val3 = (t[*x].val3 + 3LL * f2 * t[*x].val1 % Mod) % Mod;
t[*x].val3 = (t[*x].val3 + 3LL * f * t[*x].val2 % Mod) % Mod;
// 修改平方和
t[*x].val2 = (t[*x].val2 + f2 * (r - l + 1) % Mod) % Mod;
t[*x].val2 = (t[*x].val2 + 2LL * f * t[*x].val1 % Mod) % Mod;
// 修改和
t[*x].val1 = (t[*x].val1 + f * (r - l + 1) % Mod) % Mod;
// 打加标记
t[*x].add = (t[*x].add + f) % Mod;
}
}
inline
void pushdown(int x, int l, int r, int m) {
// 标记下传左儿子
addmul(&t[x].ls, l, m, t[x].add, t[x].mul);
// 标记下传右儿子
addmul(&t[x].rs, m + 1, r, t[x].add, t[x].mul);
// 清空加标记
t[x].add = 0LL;
// 清空乘标记
t[x].mul = 1LL;
}
inline // 一个函数做完 + 和 *
void update(int *x, int l, int r, int L, int R, ll f, ll g) {
if (!*x) *x = ++cntt;
if (L <= l && r <= R) {
addmul(*x, l, r, f, g);
} else {
int m = l + r >> 1;
pushdown(*x, l, r, m);
if (L <= m)
update(&t[*x].ls, l, m, L, R, f, g);
if (m + 1 <= R)
update(&t[*x].rs, m + 1, r, L, R, f, g);
pushup(*x);
}
}
// 区间加
update(&rt, 1, N, L, R, k, 1LL);
// 区间乘
update(&rt, 1, N, L, R, 0LL, k);
// 区间赋值
update(&rt, 1, N, L, R, k, 0LL);

题解 ICPC 2019 SH 区域赛 F 树上简单问题的更多相关文章

  1. ICPC 2019 徐州网络赛

    ICPC 2019 徐州网络赛 比赛时间:2019.9.7 比赛链接:The Preliminary Contest for ICPC Asia Xuzhou 2019 赛后的经验总结 // 比赛完才 ...

  2. HDU-5532//2015ACM/ICPC亚洲区长春站-重现赛-F - Almost Sorted Array/,哈哈,水一把区域赛的题~~

    F - Almost Sorted Array Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I64d & ...

  3. ICPC 2018 焦作区域赛

    // 2019.10.7 练习赛 // 赛题来源:2018 ICPC 焦作区域赛 // CF链接:http://codeforces.com/gym/102028 A Xu Xiake in Hena ...

  4. ACM-ICPC 2019南昌网络赛F题 Megumi With String

    ACM-ICPC 南昌网络赛F题 Megumi With String 题目描述 给一个长度为\(l\)的字符串\(S\),和关于\(x\)的\(k\)次多项式\(G[x]\).当一个字符串\(str ...

  5. (最新)2019年ICPC东亚地区-区域赛赛站网络赛以及现场赛时间安排

  6. 2019icpc徐州区域赛F

    F. The Answer to the Ultimate Question of Life, The Universe, and Everything. 我的第一道真·打表题 这次是真的打表啊,不是 ...

  7. 2017 ICPC/ACM 沈阳区域赛HDU6223

    Infinite Fraction Path Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java ...

  8. Tournament ZOJ - 4063 (青岛区域赛 F 打表)

    打表题.. 规律是找出来了 奈何优化不了 .... #include <iostream> #include <cstdio> #include <sstream> ...

  9. HDU 4818 RP problem (高斯消元, 2013年长春区域赛F题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4818 深深地补一个坑~~~ 现场赛坑在这题了,TAT.... 今天把代码改了下,过掉了,TAT 很明显 ...

  10. HDU 4786 最小生成树变形 kruscal(13成都区域赛F)

    Fibonacci Tree Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)To ...

随机推荐

  1. 704 二分查找 golang实现

    二分查找(Binary Search)是一种高效的查找算法,适用于 有序数组 或 有序列表.它的基本思想是通过将搜索范围逐渐缩小到目标元素所在的一半,从而大大减少查找的次数. 二分查找的基本原理 排序 ...

  2. RxJS 系列 – 目录

    请按顺序阅读 概念篇 Observable & Creation Operators Subject Observable to Subject (Hot, Cold, Warm, conne ...

  3. PTA甲级—树

    1.树的遍历 1004 Counting Leaves (30分) 基本的数据结构--树,复习了链式前向星,bfs遍历判断即可 #include <cstdio> #include < ...

  4. 大模型应用开发初探 : 快速直观感受RAG

    大家好,我是Edison. 上一篇,我们了解了什么如何让一些开源小参数量模型具有函数调用的能力.这一篇,我们来快速了解下RAG(检索增强生成)并通过一个简单的DEMO来直观感受一下它的作用. RAG是 ...

  5. element表单校验 【登录】

    async btnOK () { // 1. 表单校验 (调用表单的校验方法获取校验结果) // this.$refs.formRef.validate(function (valid) { // c ...

  6. .NET 内存管理两种有效的资源释放方式

    前言 嗨,大家好!今天我们要聊一聊 .NET 中的内存管理.你知道吗?虽然 .NET 有一个很好的垃圾回收系统来自动清理不再使用的对象,但在某些情况下,我们还需要自己动手来释放一些特殊的资源,比如打开 ...

  7. 还在使用昂贵的虚拟机?来试试 Devbox,便宜 6 倍!

    这篇小短文来介绍一下用虚拟机的场景是怎么被 Devbox 全方位碾压的. Devbox 唯一弱点是公网出口的地方不分配独立的 IP 地址,但是这对我们绝大多数场景是没有影响的,通过域名和端口访问我们的 ...

  8. 墙裂建议收藏,100道Python练手题目

    墙裂建议收藏,100道Python练手题目 目录** 实例001:数字组合 实例002:"个税计算" 实例003:完全平方数 实例004:这天第几天 实例005:三数排序 实例00 ...

  9. Windows 记录一次磁盘相关的PC卡顿问题

    我的电脑最近经常抽疯,时不时卡顿一次 检查系统事件日志,会有这俩个: 发出了对设备 \Device\RaidPort0 的重置. 已在磁盘 0 (PDO 名称: \Device\0000003a)的逻 ...

  10. 版本库控制系统的切磋之路[Git & SVN]

    集中式和分布式   集中式版本库控制系统 :SVN ; 分布式版本库控制系统 :Git . 集中式 版本库是存在中央服务器的.干活使用的是自己的电脑,每次干活前都是从服务器上拉下最新的代码版本,然后才 ...