我丢 之前sun在某校集训给我看过 当时也没想起来 今天补省集的锅的时候发现 wok这题我还听过?!

身败名裂.jpg (可是你记性不好这事情不已经人尽皆知了吗?

咳咳 回归正题

考虑对于两个同色的点:

1)不构成祖先关系

那么两个子树里的点都不能选 相当于矩形覆盖

2)构成祖先关系

祖先刨掉一个子树,儿子子树不能选

拆成两个矩形

最后考虑统计答案,发现对称做然后(总点数-答案)/2就是答案

(因为对角线上的点总是合法的 所以要加上qwq)

然后就是矩形的并数点了 直接扫描线+线段树就好了

//Love and Freedom.
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#include<vector>
#include<cassert>
#define ll long long
#define inf 20021225
#define N 100010
#define pb push_back
using namespace std;
int read()
{
int s=,f=; char ch=getchar();
while(ch<''||ch>''){if(ch=='-') f=-; ch=getchar();}
while(ch>=''&&ch<='') s=s*+ch-'',ch=getchar();
return f*s;
}
//--------- tree -----------
struct edge{int to,lt;}e[N<<];
int in[N],cnt,dep[N],sz[N],f[N][],dfn[N],tms,idfn[N];
void add(int x,int y)
{
e[++cnt].to=y; e[cnt].lt=in[x]; in[x]=cnt;
e[++cnt].to=x; e[cnt].lt=in[y]; in[y]=cnt;
}
void dfs(int x)
{
dfn[x]=++tms; idfn[tms]=x; sz[x]=;
for(int i=;i<;i++) f[x][i]=f[f[x][i-]][i-];
for(int i=in[x];i;i=e[i].lt)
{
int y=e[i].to; if(y==f[x][]) continue;
dep[y]=dep[x]+; f[y][]=x; dfs(y); sz[x]+=sz[y];
}
}
int LCA(int x,int y)
{
if(dep[x]<dep[y]) swap(x,y);
int len=dep[x]-dep[y];
for(int i=;i<;i++) if(len>>i&)
x=f[x][i];
if(x==y) return x;
for(int i=;~i;i--) if(f[x][i]!=f[y][i])
x=f[x][i],y=f[y][i];
return f[x][];
}
int col[N];
struct node
{
int xd,xu,y,v;
}p[N*];
bool operator<(node a,node b){return a.y<b.y;}
//----------- SGT ------------
// 0->not fully covered >0 -> fully covered
#define ls x<<1
#define rs x<<1|1
int s[N<<],tag[N<<];
void insert(int x,int l,int r,int LL,int RR,int v)
{
if(RR<LL) return;
if(LL<=l&&RR>=r)
{
tag[x]+=v;
if(tag[x]>) s[x]=r-l+;
else if(l==r) s[x]=;
else s[x]=s[ls]+s[rs];
return;
}
int mid=l+r>>;
if(LL<=mid) insert(ls,l,mid,LL,RR,v);
if(mid<RR) insert(rs,mid+,r,LL,RR,v);
if(!tag[x]) s[x]=s[ls]+s[rs];
}
vector<int> cc[N];
int tot;
int main()
{
//freopen("tree3-4.in","r",stdin);
int n=read();
for(int i=;i<=n;i++) col[i]=read(),cc[col[i]].pb(i);
for(int i=;i<n;i++) add(read(),read()); dfs();
for(int i=;i<=n;i++)
for(int j=;j<cc[i].size();j++) for(int k=j+;k<cc[i].size();k++)
{
int x=cc[i][j],y=cc[i][k],z=LCA(x,y);
if(z==x||z==y)
{
if(z==y) swap(x,y);
int len=dep[y]-dep[x]-; x=y;
for(int i=;i<;i++) if(len>>i&)
x=f[x][i];
p[++tot]=(node){,dfn[x]-,dfn[y],};
p[++tot]=(node){,dfn[x]-,dfn[y]+sz[y],-};
p[++tot]=(node){dfn[x]+sz[x],n,dfn[y],};
p[++tot]=(node){dfn[x]+sz[x],n,dfn[y]+sz[y],-}; p[++tot]=(node){dfn[y],dfn[y]+sz[y]-,,};
p[++tot]=(node){dfn[y],dfn[y]+sz[y]-,dfn[x],-};
p[++tot]=(node){dfn[y],dfn[y]+sz[y]-,dfn[x]+sz[x],};
p[++tot]=(node){dfn[y],dfn[y]+sz[y]-,n+,-};
}
else
{
p[++tot]=(node){dfn[x],dfn[x]+sz[x]-,dfn[y],};
p[++tot]=(node){dfn[x],dfn[x]+sz[x]-,dfn[y]+sz[y],-};
p[++tot]=(node){dfn[y],dfn[y]+sz[y]-,dfn[x],};
p[++tot]=(node){dfn[y],dfn[y]+sz[y]-,dfn[x]+sz[x],-};
}
}
sort(p+,p+tot+); ll ans=;
for(int i=;i<=tot;i++)
{
insert(,,n,p[i].xd,p[i].xu,p[i].v);
if(i!=tot && p[i].y!=p[i+].y)
ans+=1ll*(p[i+].y-p[i].y)*s[];
}
printf("%lld\n",(1ll*n*(n+)-ans)>>);
return ;
}

LOJ6279 果树的更多相关文章

  1. LOJ6276:果树——题解

    https://loj.ac/problem/6276#submit_code NiroBC 姐姐是个活泼的少女,她十分喜欢爬树,而她家门口正好有一棵果树,正好满足了她爬树的需求.这颗果树有N 个节点 ...

  2. Jmeter查看结果树Unicode编码转中文方法

    本文为转载微信公众号文章,如作者发现后不愿意,请联系我进行删除 在jmeter工具的使用中,不管是测试接口还是调试性能时,查看结果树必不可少,然而在查看响应数据时,其中的中文经常以Unicode的编码 ...

  3. 【线段树 扫描线 二维数点】loj#6276. 果树

    路径计数转成二维数点很妙啊 题目描述 NiroBC 姐姐是个活泼的少女,她十分喜欢爬树,而她家门口正好有一棵果树,正好满足了她爬树的需求. 这颗果树有 $N$ 个节点,标号 $1 \ldots N$ ...

  4. Jmeter学习笔记(七)——监听器元件之察看结果树

    在jmeter中,如果我们需要查看请求结果就需要添加查看结果树,这个监听器元件有那些功能呢? 一.察看结果树界面如下 二.察看结果树界面功能说明 1.所有数据写入文件 (1)文件名:可以通过浏览,选择 ...

  5. 【jmeter】将“察看结果树”中的数据保存到本地

    操作说明: 1. "察看结果树"页面,[配置]导出项: 2. "察看结果树"页面,[文件名]选框输入导出文件及路径:  3. 点击jmeter[启动]按钮,响应 ...

  6. 题解——loj6279 数列分块入门3 (分块)

    用set维护有序序列 或许sort也可以,但这题的前驱定义是严格小于 所以要去重 然后就是记得自己打的加法tag在query的时候一定要算上 话说这题数据有点fake啊忘了查询算上自己的标记了还有70 ...

  7. jmeter-----查看结果树

    在编写接口测试脚本的时候,需要进行调试和查看结果是否正常的情况,这个时候可以使用查看结果树组件进行. 查看结果树中展示了每一个取样器的结果.请求信息和响应信息,可以查看这些内容去分析脚本是否存在问题. ...

  8. Jmeter查看结果树

    取样结果: Thread Name: test 1-2                                                     线程名称:测试1 - 2Sample S ...

  9. jmete察看结果树和body data乱码问题的解决办法

    jmeter察看结果树乱码问题的解决办法: (1)在jmeter的bin目录下找到jmeter.properties这个文件添加sampleresult.default.encoding=utf-8 ...

随机推荐

  1. 在WCF程序中动态修改app.config配置文件

    今天在个WCF程序中加入了修改配置文件的功能.我是直接通过IO操作修改的app.config文件内容,修改后发现发现其并不生效,用Google搜了一下,在园子里的文章动态修改App.Config 和w ...

  2. Git-Runoob:Git 创建仓库

    ylbtech-Git-Runoob:Git 创建仓库 1.返回顶部 1. Git 创建仓库 本章节我们将为大家介绍如何创建一个 Git 仓库. 你可以使用一个已经存在的目录作为Git仓库. git ...

  3. 激活Win Server 2008 R2 Datacenter

    直接手撸KMS命令 管理员打开cmd输入: slmgr /skms kms.03k.org 然后用这个Key: 74YFP-3QFB3-KQT8W-PMXWJ-7M648

  4. Django框架效率问题的解决方法和总…

    由于项目的需要,学习了Django框架,Django框架的MTV很清晰,通过MTV能够很好地了解Django框架的内部机理.但是在使用过程中发现了一个严重的问题,就是当有大量IO(写数据库操作)的时候 ...

  5. 项目中引入kafka

    项目如果需要引入kafka,可以从以下几个流程走: 1.pom文件引对应的jar包 <dependency> <groupId>org.apache.kafka</gro ...

  6. 应用安全 - 无文件攻击 - Office漏洞 - 汇总

    CVE-2017-0199 Date: -1 类型: 弹窗|内网穿透导致远程代码执行 影响范围: Microsoft Office 2007 Service Pack 3 Microsoft Offi ...

  7. win10家庭版安装Docker (Docker Toolbox)

    开启CPU的虚拟化功能(自行百度)之前安装了VM所以这部跳过.具体查看可以打开任务管理器->性能->cpu 查看是否有 虚拟化:已启用字样 下载Docker Toolbox  下载地址 h ...

  8. python+selenium元素定位之XPath学习02

    XPath 语法 XPath 使用路径表达式来选取 XML 文档中的节点或节点集.节点是通过沿着路径 (path) 或者步 (steps) 来选取的. XML 实例文档 我们将在下面的例子中使用这个 ...

  9. HDU 1864 最大报销额 0-1背包

    HDU 1864 最大报销额 0-1背包 题意 现有一笔经费可以报销一定额度的发票.允许报销的发票类型包括买图书(A类).文具(B类).差旅(C类),要求每张发票的总额不得超过1000元,每张发票上, ...

  10. Luogu P5330 [SNOI2019]数论

    题目 如果\(P>Q\)的话我们先交换一下\(P,Q\). 我们先枚举所有满足第一个条件的数,对于\(x\equiv a_i(mod\ P)\),设\(x=a_i+kP(k\in[0,\lflo ...