我丢 之前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. Delphi XE2 之 FireMonkey 入门(33) - 控件基础: TFmxObject: SaveToStream、LoadFromStream、SaveToBinStream、LoadFromBinStream

    Delphi XE2 之 FireMonkey 入门(33) - 控件基础: TFmxObject: SaveToStream.LoadFromStream.SaveToBinStream.LoadF ...

  2. 如何在linux上部署vue项目

    安装nginx的前奏 安装依赖 yum -y install gcc zlib zlib-devel pcre-devel openssl openssl-devel 创建一个文件夹 cd /usr/ ...

  3. Failure to find com.oracle:ojdbc6:jar:11.2.0.1.0

    报错原因:oracle的ojdbc.jar是收费的,maven的中央仓库是没有的,需要下载到本地,然后打包进maven仓库 1.下载ojdbc6-11.2.0.1.0.jar包 http://cent ...

  4. HTML——超级链接 表格 框架

  5. 使用TestNG框架测试用例执行顺序问题

    既然是讨论执行顺序问题,那么用例肯定是批量执行的,批量执行的方法有mvn test.直接运行testng.xml文件,其中直接运行testng.xml文件的效果与pom文件中配置执行testng.xm ...

  6. IP子网的划分

    一.划分子网的具体步骤 已知192.168.1.0/24,划分8个子网(一个ip划分8个子网,即网络位不再是24位)1100 0000.1010 1000.0000 0001.0000 00001 . ...

  7. Python基础语法之常量与变量

    一.变量的命名规则 只能以下划线,数字和字母组成,不可以是特殊字符: 不可以以数字开头: 关键字不可作为变量名: 变量名区分大小写: 要具有描述性: 二.常量 python中并没有关键字const,在 ...

  8. tensorflow实践学习一

    前言: 最近开始学习tensorflow框架,主要参考<TensorfFlow技术解析与实战>这本书,如果有同学需要这本书的PDF版,可以给我评论里留下邮箱,我看到了会发给你 正文 1.T ...

  9. 应用安全 - 工具 | 平台 - Weblogic - 漏洞 - 汇总

    控制台路径 | 弱口令  前置条件 /console CVE-2016-0638  Date 类型远程代码执行 影响范围10.3.6, 12.1.2, 12.1.3, 12.2.1  CVE-2016 ...

  10. Go语言入门篇-复合数据类型

    复合数据类型 主要讨论四种类型——数组.slice.map和结构体 数组和结构体聚合类型   --数组和结构体都是有固定内存大小的数据结构 --数组:由同构的元素组成——每个数组元素都是完全相同的类型 ...