P3038 [USACO11DEC] Grass Planting G

news/2025/1/14 19:29:05/文章来源:https://www.cnblogs.com/Yuan-Jiawei/p/18437087

题意

image

思路

我们可以使用树链剖分,将每条边的边权下放,将其当作点权处理,每次操作都要忽略 lca 那个点,因为它所对应的点并不在路径上。

image

代码

#include <bits/stdc++.h>using namespace std;const int N = 100010;struct edge {int to, next;
} e[N * 2];int head[N], idx = 1;void add(int u, int v) {idx++;e[idx].to = v;e[idx].next = head[u];head[u] = idx;
}struct node {int sum, add;
} tr[N << 2];void pushup(int u) {tr[u].sum = tr[u << 1].sum + tr[u << 1 | 1].sum;
}void addtag(int u, int c, int l, int r) {tr[u].add += c;tr[u].sum += c * (r - l + 1);
}void pushdown(int u, int l, int r) {if (tr[u].add) {int mid = l + r >> 1;addtag(u << 1, tr[u].add, l, mid);addtag(u << 1 | 1, tr[u].add, mid + 1, r);tr[u].add = 0;}
}void modify(int u, int l, int r, int pl, int pr, int v) {if (pl <= l && r <= pr) {addtag(u, v, l, r);return;}pushdown(u, l, r);int mid = l + r >> 1;if (pl <= mid) modify(u << 1, l, mid, pl, pr, v);if (pr > mid) modify(u << 1 | 1, mid + 1, r, pl, pr, v);pushup(u);
}int query(int u, int l, int r, int pl, int pr) {if (pl <= l && r <= pr) return tr[u].sum;pushdown(u, l, r);int mid = l + r >> 1, sum = 0;if (pl <= mid) sum += query(u << 1, l, mid, pl, pr);if (pr > mid) sum += query(u << 1 | 1, mid + 1, r, pl, pr);return sum;
}int son[N], sz[N], fa[N], dep[N];void dfs1(int u, int f) {sz[u] = 1, fa[u] = f, dep[u] = dep[f] + 1;for (int i = head[u]; i; i = e[i].next) {int to = e[i].to;if (to == f) continue;dfs1(to, u);sz[u] += sz[to];if (sz[son[u]] < sz[to]) son[u] = to;}
}int top[N], dfn[N], rk[N], t_cnt;
int n, m;void dfs2(int u, int t) {top[u] = t, dfn[u] = ++t_cnt, rk[t_cnt] = u;if (son[u]) dfs2(son[u], t);for (int i = head[u]; i; i = e[i].next) {int to = e[i].to;if (to == fa[u] || to == son[u]) continue;dfs2(to, to);}
}void update(int u, int v) {while (top[u] != top[v]) {if (dep[top[u]] < dep[top[v]]) swap(u, v);modify(1, 1, n, dfn[top[u]], dfn[u], 1);u = fa[top[u]];}if (dep[u] > dep[v]) swap(u, v);if (u == v) return;modify(1, 1, n, dfn[u] + 1, dfn[v], 1);
}int ask(int u, int v) {int sum = 0;while (top[u] != top[v]) {if (dep[top[u]] < dep[top[v]]) swap(u, v);sum += query(1, 1, n, dfn[top[u]], dfn[u]);u = fa[top[u]];}if (dep[u] > dep[v]) swap(u, v);if (u == v) return sum;sum += query(1, 1, n, dfn[u] + 1, dfn[v]);return sum;
}void solve() {cin >> n >> m;for (int i = 1; i < n; i++) {int u, v;cin >> u >> v;add(u, v), add(v, u);}dfs1(1, 0);dfs2(1, 1);char opt;int x, y;while (m--) {cin >> opt >> x >> y;if (opt == 'P') update(x, y);else cout << ask(x, y) << '\n';}
}int main() {ios::sync_with_stdio(false);cin.tie(nullptr);solve();return 0;
}

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

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

相关文章

九月二十八

以下代码的输出结果是什么? int X=100; int Y=200; System.out.println("X+Y="+X+Y); System.out.println(X+Y+"=X+Y"); 为什么会有这样的输出结果? 输出结果是: X+Y=100200 100200=X+Y 出现这样的输出结果是因为在Java中,当多个值连接在一起时,会根据…

九月二十七2

当需要处理非常大或非常小的数值时,应选择float或double类型。 当需要处理字符或需要较大范围的无符号整数时,应选择char类型。 当需要在内存和处理速度之间做出权衡时,可以根据需要选择适当的整数类型(byte, short, int, long)。 对于需要精确计算的场景,应避免使用浮点…

PARTVI-Oracle数据库管理与开发-数据库管理员和开发人员的主题

17.数据库管理员和开发人员的主题 17.1. 数据库安全概述 通常情况下,数据库安全涉及用户认证、加密、访问控制和监控。 17.1.1. 用户账户 每个Oracle数据库都有一个有效数据库用户的列表。数据库包含几个默认账户,包括默认的管理员账户SYSTEM(参见第2-5页的“SYS和SYSTEM模式…

crypt.h:No such file or directory 报错处理

crypt.h:No such file or directory 报错处理crypt.h:No such file or directory 报错处理前言:本文初编辑于2024年9月28日 CSDN主页:https://blog.csdn.net/rvdgdsva 博客园主页:https://www.cnblogs.com/hassle大!萌!神! “crypt.h: No such file or directory” 这个…

深入理解 Nuxt.js 中的 app:error:cleared 钩子

title: 深入理解 Nuxt.js 中的 app:error:cleared 钩子 date: 2024/9/28 updated: 2024/9/28 author: cmdragon excerpt: Nuxt.js 中的 app:error:cleared 钩子的用途及其实现方式。这个钩子为开发者提供了一种优雅的方式来处理错误清除后的状态恢复和用户反馈。 categorie…

新手指南-新人入职-maven相关

一、前言 入职后,发现公司是用Maven对项目进行管理和构建。 一般来说,自己先确定以下几点: 1、公司对版本是否有要求。 2、是否要求IDEA对maven有特殊的配置。 3、确定自己的 MAVEN_HOME 系统环境是否配置。 4、确定maven中的setting.xml配置文件是否改成了公司要求。 Maven…

PARTV-Oracle实例架构-应用和网络架构

16. 应用和网络架构 16.1. Oracle应用架构 在本章的上下文中,应用架构指的是数据库应用程序连接到 Oracle 数据库的计算环境。 16.1.1. 客户端与服务端架构概述 在 Oracle 数据库环境中,数据库应用程序和数据库被分离成客户端/服务器架构:客户端运行数据库应用程序,例如 SQ…

AB plc设备数据 转profinet IO项目案例

VFBOX协议转换网关支持各种PLC,DLT645,modbus,HJ212,opc ua,opc da,IEC104,IEC61850,EthernetIP,Profinet IO,CCLink,EtherCAT,bacnet,DNP3目录 1 案例说明 1 2 VFBOX网关工作原理 1 3 准备工作 2 4 网关采集AB PLC数据 2 5 用PROFINET IO协议转发数据 4 6 案例总…

代码生成器实践总结

最近,又用我的脚本管理,写了一个代码生成器。 用在一个.net core Web MVC项目中,想要把原来的一些Area,拷贝替换表名。 业务上来说是:把推广模块,单独复制出一个推广-外部渠道的模块。专门给公司外部的推广人员用,但是不影响原来的功能。 本质结构代码生成器 = 模板 + 替…

【管理】销售管理到底应该怎么管?

销售是个数字游戏,销售管理的最终目的就是完成销售业绩。有人说销售管理是门艺术,有人说销售管理是科学。销售是一门艺术,但是可以通过科学的方式将这些艺术固化很多人对销售管理的认识存在很多不同,我们尝试用最为平时的语言总结一下销售管理到底应该管什么?到底怎么管?…

ES6箭头函数的使用

使用箭头函数的目的:引入箭头函数目的是更加更加简短的函数写法并且不绑定this,箭头函数的语法比函数表达式更加简洁 使用场景:箭头函数更加适用于哪些本来需要匿名函数的地方 定义语法:const fn = () => {}使用方式一:括号里面加形参// 箭头函数const fn = (x) => …