Codeforces Round #425 (Div. 2) - D
题目链接:http://codeforces.com/contest/832/problem/D
题意:给定一棵n个点的树,然后给你q个询问,每个询问为三元组(a,b,c),问你从这三个点中选取一个作为终点,一个作为Misha的起点,一个作为Grisha的起点。然后每天早上Misha从起点到终点所经过的点都是标记为1, 傍晚Grisha从起点到终点所经过的点中带有标记的点的数目最多是多少?
思路:对于每个询问,我们枚举终点(共3种情况),其余两个点作为一个作为M的起点一个作为G的起点,然后问题就是M的起点到终点这条路径的点赋值1,统计G的起点到终点这条路径的1的个数,然后3种情况取个最大值即可。 然后就是经典的树链剖分题目,树剖之后就是区间覆盖+区间查询问题了。 起初用的是线段树,然后终测TLE掉了(可能我写的线段树不够优美,被卡常了),后来换成树状数组来维护区间覆盖,区间查询就AC掉了。
- #define _CRT_SECURE_NO_DEPRECATE
- #include<iostream>
- #include<cstdio>
- #include<cstring>
- #include<algorithm>
- #include<string>
- #include<queue>
- #include<vector>
- #include<time.h>
- #include<cmath>
- using namespace std;
- typedef long long int LL;
- const int MAXN = 1e5 + ;
- const int INF = 0x3f3f3f3f;
- const int mod = 1e9 + ;
- int fa[MAXN],top[MAXN],deep[MAXN],num[MAXN],p[MAXN],fp[MAXN],son[MAXN];
- int pos,cp[MAXN],n,q;
- LL bit0[MAXN],bit1[MAXN];
- vector<int>edge[MAXN];
- void init(){
- pos = ;
- memset(bit0,,sizeof(bit0));
- memset(bit1,,sizeof(bit1));
- memset(son, -, sizeof(son));
- }
- void dfs1(int u, int pre, int d){
- deep[u] = d; fa[u] = pre; num[u] = ;
- for (int i = ; i < edge[u].size(); i++){
- int v = edge[u][i];
- if (v != pre){
- dfs1(v, u, d + );
- num[u] += num[v];
- if (son[u] == - || num[v] > num[son[u]]
- ){
- son[u] = v;
- }
- }
- }
- }
- void dfs2(int u, int sp){
- top[u] = sp; p[u] = pos++; fp[p[u]] = u;
- if (son[u] == -){
- return;
- }
- dfs2(son[u], sp);
- for (int i = ; i < edge[u].size(); i++){
- int v = edge[u][i];
- if (v != fa[u] && v != son[u]){
- dfs2(v, v);
- }
- }
- }
- //BIT
- void Add(LL *b,int i,LL val){
- while (i<=n){
- b[i]+=val; i+=i&-i;
- }
- }
- LL Sum(LL *b,int i){
- LL s=;
- while (i>){
- s+=b[i]; i-=i&-i;
- }
- return s;
- }
- void Modify(int l,int r,int val){ //区间[l,r] + val
- //printf("M:%d %d %d\n",l,r,val);
- Add(bit0,l,-val*(l-));
- Add(bit1,l,val);
- Add(bit0,r+,val*r);
- Add(bit1,r+,-val);
- }
- int Query(int l,int r){ //区间[l,r] 1 的个数
- //printf("Q:%d %d\n",l,r);
- LL res=;
- res+=Sum(bit0,r)+1LL*Sum(bit1,r)*r;
- res-=Sum(bit0,l-)+1LL*Sum(bit1,l-)*(l-);
- return res;
- }
- void solveC(int u, int v,int val){ //修改链
- int f1 = top[u], f2 = top[v];
- while (f1!=f2){
- if (deep[f1] < deep[f2]){
- swap(f1, f2); swap(u, v);
- }
- Modify(p[f1], p[u], val);
- u = fa[f1];
- f1 = top[u];
- }
- if (deep[u] > deep[v]){
- swap(u, v);
- }
- Modify(p[u], p[v], val);
- }
- int solveQ(int u, int v){ //查询链
- int f1 = top[u], f2 = top[v];
- int tmp = ;
- while (f1 != f2){
- if (deep[f1] < deep[f2]){
- swap(f1, f2); swap(u, v);
- }
- tmp+=Query(p[f1], p[u]);
- u = fa[f1]; f1 = top[u];
- }
- if (deep[u] > deep[v]){
- swap(u, v);
- }
- tmp+=Query(p[u], p[v]);
- return tmp;
- }
- int solve(int s, int t, int f){
- solveC(s, f, );
- int tmp = solveQ(t, f);
- solveC(s, f, -);
- return tmp;
- }
- int main(){
- #ifdef kirito
- freopen("in.txt", "r", stdin);
- freopen("out.txt", "w", stdout);
- #endif
- while (~scanf("%d%d",&n,&q)){
- init();
- for (int i = ; i <= n; i++){
- edge[i].clear();
- }
- for (int i = ; i <= n; i++){
- scanf("%d", &cp[i]);
- edge[cp[i]].push_back(i);
- edge[i].push_back(cp[i]);
- }
- dfs1(, , );
- dfs2(, );
- for (int i = ; i <= q; i++){
- int a, b, c,res=;
- scanf("%d%d%d", &a, &b, &c);
- res = max(res, solve(a, b, c));
- res = max(res, solve(a, c, b));
- res = max(res, solve(b, c, a));
- printf("%d\n", res);
- }
- }
- return ;
- }
Codeforces Round #425 (Div. 2) - D的更多相关文章
- Codeforces Round #425 (Div. 2)C
题目连接:http://codeforces.com/contest/832/problem/C C. Strange Radiation time limit per test 3 seconds ...
- Codeforces Round #425 (Div. 2)
A 题意:给你n根棍子,两个人每次拿m根你,你先拿,如果该谁拿的时候棍子数<m,这人就输,对手就赢,问你第一个拿的人能赢吗 代码: #include<stdio.h>#define ...
- Codeforces Round #425 (Div. 2) Problem D Misha, Grisha and Underground (Codeforces 832D) - 树链剖分 - 树状数组
Misha and Grisha are funny boys, so they like to use new underground. The underground has n stations ...
- Codeforces Round #425 (Div. 2) Problem C Strange Radiation (Codeforces 832C) - 二分答案 - 数论
n people are standing on a coordinate axis in points with positive integer coordinates strictly less ...
- Codeforces Round #425 (Div. 2) Problem B Petya and Exam (Codeforces 832B) - 暴力
It's hard times now. Today Petya needs to score 100 points on Informatics exam. The tasks seem easy ...
- Codeforces Round #425 (Div. 2) Problem A Sasha and Sticks (Codeforces 832A)
It's one more school day now. Sasha doesn't like classes and is always bored at them. So, each day h ...
- Codeforces Round #425 (Div. 2) B. Petya and Exam(字符串模拟 水)
题目链接:http://codeforces.com/contest/832/problem/B B. Petya and Exam time limit per test 2 seconds mem ...
- Codeforces Round #425 (Div. 2))——A题&&B题&&D题
A. Sasha and Sticks 题目链接:http://codeforces.com/contest/832/problem/A 题目意思:n个棍,双方每次取k个,取得多次数的人获胜,Sash ...
- Codeforces Round #425 (Div. 2) B - Petya and Exam
地址:http://codeforces.com/contest/832/problem/B 题目: B. Petya and Exam time limit per test 2 seconds m ...
- Codeforces Round #425 (Div. 2) C - Strange Radiation
地址:http://codeforces.com/contest/832/problem/C 题目: C. Strange Radiation time limit per test 3 second ...
随机推荐
- Android 输入法截取key优先于view
为了验证编写了个例子 首先是输入法 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 public class RemoteKeyboard exte ...
- 20180912-Java实例02
Java 实例 – 删除字符串中的一个字符 以下实例中我们通过字符串函数 substring() 函数来删除字符串中的一个字符,我们将功能封装在 removeCharAt 函数中. // Main.j ...
- Android操作系统中11种传感器的介绍【转】
本文转载自:http://www.oschina.net/question/163910_28354 在Android2.3 gingerbread系统中,google提供了11种传感器供应用层使用. ...
- JSONPath解析json
JSONPath - 用于JSON的XPath 用来解析多层嵌套的json数据;JsonPath 是一种信息抽取类库,是从JSON文档中抽取指定信息的工具. 考虑到接下来计划开发一个自动化测试平台,在 ...
- 【SD系列】SAP 退货冲账过账成本更新
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[SD系列]SAP 退货冲账过账成本更新 前 ...
- Spring MVC配置文件
都说开发Spring Web程序的配置文件很繁琐,所以就写了一篇配置博客, 首先是pom.xml文件 <project xmlns="http://maven.apache.org/P ...
- Node.js实战9:用EventEmitter触发和响应事件。
Nodejs有一个重要的事件模块:EventEmitter. 它在Nodejs的内置及第三方模块中被大量使用,许多Nodejs项目的架构都是用它实现的. 可见,EventEmitter对于学习Node ...
- Win10不能远程其他远程计算机的解决办法
Win10不能远程其他远程计算机的解决办法 转自: https://blog.csdn.net/qq_38197830/article/details/69488236 首先打开控制面板——> ...
- python字典使用总结
作者:python技术人 博客:https://www.cnblogs.com/lpdeboke 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值 key=>value 对用冒号 ...
- MySql-8.0.16版本部分安装问题修正
本帖参考网站<https://blog.csdn.net/lx318/article/details/82686925>的安装步骤,并对8.0.16版本的部分安装问题进行修正 在MySQL ...