P3605 [USACO17JAN]Promotion Counting P dfs序

传送门

文章目录

  • 题意:
  • 思路:

题意:

在这里插入图片描述

思路:

这个题可以用各种姿势a掉,树启和线段树合并都可以,比较无脑。下面给一个解决这种问题比较巧妙的做法。
考虑暴力怎么写,我们先将每个点的权值离散化一下,每到一个点就把树状数组清空,让后在树状数组中加上这个子树的值,用树状数组查询pj>pip_j>p_ipj>pi的数量。
我们优化以上算法,还是先离散化,也是用到了树状数组。
考虑对于一个点,当dfsdfsdfs遍历这个点会遍历两次 ,第一次是从父亲节点到这个点,第二次是从他的子节点回溯回来。我们在回溯的时候加上这个节点的权值,那么当回溯到这个点的时候,树状数组中存的值包含了以这个点为根的子树的全部权值,当然里面可能还有别的点的值(即"垃圾"值),如果我们按照之前一遍一清空的话复杂度是O(n2)O(n^2)O(n2)的,我们就是要优化这里。现在想想,如果能把树状数组中那些”垃圾“值减去不就行了吗?我们如何才能知道那些值呢?我们惊奇的发现第一次到这个点的时候树状数组中存的不就是这个值嘛?所以我们定义一个ansansans,第一次到这个点的时候减去sum(se)−sum(a[u])sum(se)-sum(a[u])sum(se)sum(a[u]),回溯的时候加上sum(se)−sum(a[u])sum(se)-sum(a[u])sum(se)sum(a[u])即可,这个时候即为答案啦。

//#pragma GCC optimize(2)
#include<cstdio>
#include<iostream>
#include<string>
#include<cstring>
#include<map>
#include<cmath>
#include<cctype>
#include<vector>
#include<set>
#include<queue>
#include<algorithm>
#include<sstream>
#include<ctime>
#include<cstdlib>
#define X first
#define Y second
#define L (u<<1)
#define R (u<<1|1)
#define pb push_back
#define mk make_pair
#define Mid (tr[u].l+tr[u].r>>1)
#define Len(u) (tr[u].r-tr[u].l+1)
#define random(a,b) ((a)+rand()%((b)-(a)+1))
#define db puts("---")
#define lowbit(x) ((x)&(-x))
using namespace std;//void rd_cre() { freopen("d://dp//data.txt","w",stdout); srand(time(NULL)); }
//void rd_ac() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//AC.txt","w",stdout); }
//void rd_wa() { freopen("d://dp//data.txt","r",stdin); freopen("d://dp//WA.txt","w",stdout); }typedef long long LL;
typedef unsigned long long ULL;
typedef pair<int,int> PII;const int N=1000010,M=N*2,mod=1e9+7,INF=0x3f3f3f3f;
const double eps=1e-6;int n,se;
int a[N];
vector<int>v;
int tr[N];
int e[M],ne[M],h[N],idx;
int ans[N];void add(int a,int b)
{e[idx]=b,ne[idx]=h[a],h[a]=idx++;
}void addd(int x,int c)
{for(int i=x;i<=se;i+=lowbit(i)) tr[i]+=c;
}int sum(int x)
{int ans=0;for(int i=x;i;i-=lowbit(i)) ans+=tr[i];return ans;
}int find(int x)
{return lower_bound(v.begin(),v.end(),x)-v.begin();
}void dfs(int u)
{ans[u]-=sum(se)-sum(a[u]);for(int i=h[u];~i;i=ne[i]) { int ver=e[i]; dfs(ver); }ans[u]+=sum(se)-sum(a[u]);addd(a[u],1);
}int main()
{
//	ios::sync_with_stdio(false);
//	cin.tie(0);scanf("%d",&n);memset(h,-1,sizeof(h)); idx=0;for(int i=1;i<=n;i++) scanf("%d",&a[i]),v.pb(a[i]);sort(v.begin(),v.end()); v.erase(unique(v.begin(),v.end()),v.end());se=v.size();for(int i=1;i<=n;i++) a[i]=find(a[i])+1;for(int i=2;i<=n;i++){int x; scanf("%d",&x);add(x,i);}dfs(1);for(int i=1;i<=n;i++) printf("%d\n",ans[i]);return 0;
}
/**/

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

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

相关文章

推荐VSCode多语言开发,支持一键JAVA

哈喽大家周一好&#xff01;好久不见鸭&#xff0c;最近在看一本书&#xff0c;很好&#xff0c;《人类简史》&#xff0c;适合夏日星空&#xff0c;仰观宇宙之大?这个专题是“做贡献”&#xff0c;也是作为软粉&#xff0c;打算一直推广微软自己的东西&#xff0c;上一次还是…

思维--找规律--Codeforces Round #645 (Div. 2) c题

C. Celex Update 题目大意&#xff1a;给出两点的坐标&#xff0c;找出不同的路径的总数&#xff08;路径数字总和不同&#xff09; 思路&#xff1a;根据观察向下走比向右走的增加幅度加1&#xff0c;所以在第i步 向下 对sum的影响是 n-i1 所以最小数字为12。。。。y&#xf…

Codeforces Round #709 (Div. 1, based on Technocup 2021 Final Round) A. Basic Diplomacy

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 有nnn个小朋友&#xff0c;让后你要在mmm天中每天都选择一个小朋友&#xff0c;给出这mmm天都可以选哪个小朋友&#xff0c;每个小朋友选的次数不超过⌈m2⌉\left \lceil \frac{m}{2} \right \rceil⌈2m​⌉…

分布式Redis的分布式锁 Redlock

引言之前自己在用redis来实现分布式锁的时候都是基于单个Redis实例&#xff0c;也就是说Redis本身是有单点故障的&#xff0c;Redis的官方文档介绍了一种"自认为"合理的算法&#xff0c;Redlock来实现分布式Redis下的分布式锁。Martin Kleppmann写了一篇文章分析Redl…

双指针--Codeforces Round #645 (Div. 2) d题

D. The Best Vacation 题目大意&#xff1a; 算出连续x天最多的拥抱&#xff0c;一个月第i号就有i个拥抱 思路&#xff1a;双指针&#xff0c;扫描过去&#xff08;每个月每个月的计算&#xff0c;最后超出的部分再一天一天算&#xff09; 代码 &#xff1a; #include<cstd…

Educational Codeforces Round 106 (Rated for Div. 2) C. Minimum Grid Path 奇偶 + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给一个二维平面&#xff0c;起点在(0,0)(0,0)(0,0)&#xff0c;终点在(n,n)(n,n)(n,n)&#xff0c;每次只能往上和往右走&#xff0c;距离随意&#xff0c;总步数不超过nnn&#xff0c;每一步有一个代价cic_…

从CLR GC到CoreCLR GC看.NET Core对云原生的支持

内存分配概要前段时间在园子里看到有人提到了GC学习的重要性&#xff0c;很赞同他的观点。充分了解GC可以帮助我们更好的认识.NET的设计以及为何在云原生开发中.NET Core会占有更大的优势&#xff0c;这也是一个程序员成长到更高层次所需要经历的过程。在认识GC的过程中&#x…

Orac and LCM #641(div2) c题--求质因数次小指数

Orac and LCM cf地址 For the multiset of positive integers s{s1,s2,…,sk}, define the Greatest Common Divisor (GCD) and Least Common Multiple (LCM) of s as follow: gcd(s) is the maximum positive integer x, such that all integers in s are divisible on x. …

Codeforces Round #606 (Div. 2, based on Technocup 2020 Elimination Round 4) dfs + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给一张图&#xff0c;求必须经过aaa点和bbb点的路径条数。 思路&#xff1a; 通过观察我们发现&#xff0c;这个路径无非就是x−>a−>b−>yx->a->b->yx−>a−>b−>y或者x−>…

一张图带你了解 Insider Dev Tour 2019中国技术大会

点击阅读原文&#xff0c;前往微软Insider Dev Tour 全球官网

Codeforces Round #632 (Div. 2)巧用小技巧

Codeforces Round #632 (Div. 2)点这 Eugene likes working with arrays. And today he needs your help in solving one challenging task. An array c is a subarray of an array b if c can be obtained from b by deletion of several (possibly, zero or all) elements f…

Codeforces Round #606 (Div. 2, based on Technocup 2020 Elimination Round 4) 构造

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给nnn个数&#xff0c;让你构造一个尽可能大的矩阵&#xff0c;其中每个点所在的行和列都不含相等元素。 思路&#xff1a; 假设构造的答案矩阵大小为ababab且a<ba<ba<b&#xff0c;那么我们可以…

.NET项目迁移到.NET Core操作指南

这篇文章&#xff0c;汇集了大量优秀作者写的关于".NET迁移到.NET Core"资料文章以及微软官方教程文档。是我在迁移公司框架项目到.NET Core和.NET Standard时遇到的问题&#xff0c;并将相关资料整理成这篇文章。记录如何一步一步把项目迁移到.NET Core。在此感谢这…

Educational Codeforces Round 88 D. Yet Another Yet Another Task(巧枚举)

cf地址 **题目大意&#xff1a;**一个序列&#xff0c;你可以选择一个子段&#xff0c;要求去掉子段最大值后的和最大&#xff0c;求出这个最大值 **思路&#xff1a;**a[i]的范围比较小&#xff0c;可以通过枚举最大值&#xff0c;再找到最大值可以辐射的区间。经典套路了。…

Codeforces Round #607 (Div. 2) E. Jeremy Bearimy dfs + 思维

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你2∗k2*k2∗k个点的一棵树。定义GGG为任选kkk组不同的点&#xff0c;每组点的距离和的最小值。定义BBB为任选kkk组不同的点&#xff0c;每组点的距离和的最大值。让你求出GGG和BBB。 思路&#xff1a; …

EF Core 3 的 40 个中断性变更

为了修复 Entify Framework Core 中许多已发现的缺陷&#xff0c;微软在 EF Core 3 中引入了 40 个中断性变更。我们可以在微软文档中查看完整的中断性变更列表&#xff0c;本文仅列举几个主要的点。客户端查询为了突破 EF Core SQL 生成器的限制&#xff0c;默认只在客户端执行…

Codeforces Round #646 (Div. 2) E(贪心,bfs)

Codeforces Round #646 (Div. 2) E 题目大意&#xff1a; 给一棵树&#xff0c;每个节点有三个权值 A,B,C, (B,C为0或1)&#xff0c;每次你可以花费 A[u] *k的代价让A子树中的任意 k 个节点交换彼此的 B &#xff0c;问让所有节点的 BC 至少花费多少代价。 思路&#xff1a; …

Educational Codeforces Round 77 (Rated for Div. 2) D. A Game with Traps 贪心 +二分

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 给你nnn个人&#xff0c;每个人都有个能力值aia_iai​。让后在1−m1-m1−m的路上有kkk个陷阱&#xff0c;每个陷阱的范围是[li,ri][l_i,r_i][li​,ri​]&#xff0c;伤害是did_idi​&#xff0c;能力值低于d…

联手微软,Docker公司将推出Docker Desktop for WSL 2

微软最新推出的 WSL 2 在架构方面发生了重大的变化&#xff1a;它提供了一个在轻量级 VM 中运行的真正 Linux 内核。使用真正的 Linux 内核意味着可以在 Windows 上运行 ELF64 Linux 二进制文件。对 Docker 来说绝对是利好消息&#xff0c;因为这意味着 Linux 版本的 Docker 可…

SP1026 FAVDICE - Favorite Dice 期望dp

传送门 文章目录题意&#xff1a;思路&#xff1a;题意&#xff1a; 一个n面的骰子&#xff0c;求期望掷几次能使得每一面都被掷到。 思路&#xff1a; 考虑期望dpdpdp。定义f[i]f[i]f[i]表示有iii面了&#xff0c;还需要多少次能到nnn面。当前是iii面&#xff0c;所以选到新…