emm...这道题我调了一下午你敢信??

  好吧还是我太天真了。

  开始的时候以为自己线段树动态开点与合并写错了,就调;

  结果发现没问题,那就是信息维护错了。

  一开始以为自己最左右的1维护错了,后来与同学标程对拍,没问题。

  最后才发现是自己维护最长的0序列时错了,具体的说是,动态开点线段树只有操作过的地方才有实际的点,因此我就忽略了没有插过点的区间是0序列,会给序列长度贡献,因此我就错了。

  后来同学提醒才想起来。

  然而还是\(WA\)。。。。。。

  于是今天下午,坐后面的同学与老师就看到了前排一个抓狂的人,没错就是我。

  最终,当我在抓狂中冷静下来时,我看到同学的程序里是在\(DFS\)是实时记录答案,我才猛然想起来:

段树合并时,原来的树信息会被合并到另外一棵树上,这个过程中会有信息的修改与丢失,也就是说,这个过程对原来的某些信息是不安全的。

  改掉他后,我就\(A\)了。。。。。。

  真是无语了。。。。。。

  就当花一下午买个记性吧,正好暴露出我对这个东西不熟,又要复习了。

Code
#include<bits/stdc++.h>
using namespace std;
namespace STD
{
#define rr register
typedef long long ll;
const int N=100004;
const int inf=INT_MAX;
int n,m,q;
int to[N],dire[N],head[N];
template<typename T> T cmax(rr T x,rr T y){return x>y?x:y;}
template<typename T> T cmin(rr T x,rr T y){return x<y?x:y;}
inline void add(int f,int t)
{
static int num=0;
to[++num]=t;
dire[num]=head[f];
head[f]=num;
}
int read()
{
rr int x_read=0,y_read=1;
rr char c_read=getchar();
while(c_read<'0'||c_read>'9')
{
if(c_read=='-') y_read=-1;
c_read=getchar();
}
while(c_read<='9'&&c_read>='0')
{
x_read=(x_read<<3)+(x_read<<1)+(c_read^48);
c_read=getchar();
}
return x_read*y_read;
}
class sgt
{
private:
int tot;
int in;
int root[N];
int le[N*30],re[N*30];
int len[N*30],lc[N*30];
int rc[N*30];
int Merge(int,int,int,int);
void Insert(int&,int,int,int);
inline void push_up(int,int,int);
int cmax(int x,int y){return x>y?x:y;}
public:
sgt()
{
tot=0;
memset(le,127,sizeof le);
memset(re,128,sizeof re);
memset(len,128,sizeof len);
memset(lc,0,sizeof lc);
memset(rc,0,sizeof rc);
in=le[3];
}
void insert(int id,int pos){Insert(root[id],1,m,pos);}
void merge(int x,int y){root[x]=Merge(root[x],root[y],1,m);}
int query(int id)
{
if(!root[id]) return -1;
return cmax(len[root[id]],m-re[root[id]]+le[root[id]]-1);
}
}t;
inline void sgt::push_up(int id,int l,int r)
{
int mid=(l+r)>>1;
if(lc[id])
{
le[id]=le[lc[id]];
re[id]=re[lc[id]];
len[id]=max(len[lc[id]],le[id]-l);
if(rc[id])
{
len[id]=max(len[id],len[rc[id]]);
len[id]=max(len[id],le[rc[id]]-re[lc[id]]-1);
re[id]=re[rc[id]];
}
else
len[id]=max(len[id],r-re[id]);
}
else
{
if(!rc[id]) return;
le[id]=le[rc[id]];
re[id]=re[rc[id]];
len[id]=max(len[rc[id]],le[id]-l);
}
}
void sgt::Insert(int &id,int l,int r,int pos)
{
if(!id) id=++tot;
if(l==r)
{
le[id]=l;
re[id]=r;
len[id]=0;
return;
}
int mid=(l+r)>>1;
if(pos<=mid) Insert(lc[id],l,mid,pos);
else Insert(rc[id],mid+1,r,pos);
len[id]=-inf;
push_up(id,l,r);
}
int sgt::Merge(int id1,int id2,int l,int r)
{
if(!id1||!id2) return id1+id2;
if(l==r)
{
le[id1]=l;
re[id1]=r;
len[id1]=0;
return id1;
}
int mid=(l+r)>>1;
lc[id1]=Merge(lc[id1],lc[id2],l,mid);
rc[id1]=Merge(rc[id1],rc[id2],mid+1,r);
push_up(id1,l,r);
return id1;
}
int ans[N];
void dfs(int x)
{
for(rr int i=head[x];i;i=dire[i])
{
dfs(to[i]);
t.merge(x,to[i]);
}
ans[x]=t.query(x);
}
};
using namespace STD;
int main()
{
n=read(),m=read(),q=read();
for(rr int i=1;i<n;i++)
{
int u=read(),v=read();
add(u,v);
}
for(rr int i=1;i<=q;i++)
{
int u=read(),p=read();
t.insert(u,p);
}
dfs(1);
for(rr int i=1;i<=n;i++)
printf("%d\n",ans[i]);
}

Defence的更多相关文章

  1. Dedecms include\dialog\select_soft_post.php Upload Any Files To The Specified Directory Via Variable Not Initial Flaw Bypass Extension Defence

    目录 . 漏洞描述 . 漏洞触发条件 . 漏洞影响范围 . 漏洞代码分析 . 防御方法 . 攻防思考 1. 漏洞描述 综合来说,这个漏洞的根源是"register_globals = on& ...

  2. Last Defence (run time error)

    Last Defence时间限制:1000 ms | 内存限制:65535 KB描述Given two integers A and B. Sequence S is defined as follo ...

  3. UVALive 7045 Last Defence

    ProblemK. Last Defence Description Given two integersA and B. Sequence S is defined as follow: • S0 ...

  4. Last Defence (2014 西安现场赛)

    http://acm.hust.edu.cn/vjudge/contest/view.action?cid=94237#problem/K Last Defence Time Limit:3000MS ...

  5. Unity2D项目-平台、解谜、战斗! 1.2战斗组件Defence、Attack

    各位看官老爷们,这里是RuaiRuai工作室,一个做单机游戏的兴趣作坊. 接上文,我们定义了两个分别具有"攻击"和"被攻击"语义的组件CanFight和CanB ...

  6. CF175E Power Defence

    CF175E Power Defence 题意 一个塔防游戏:给定一个无限长的数轴,一个无限血的敌人要从正无穷走到负无穷.你的任务是放置三种塔,包含两种攻击塔和一种寒冰塔,使得敌人受到的伤害最大. 其 ...

  7. 8.8考试总结(NOIP模拟33)[Hunter·Defence·Connect]

    无法逃避的是自我,而无法挽回的是过去. 前言 还算可以,不过 T1 少 \(\bmod\) 了一下挂了 25pts,T2 没看清题面挂了 27pts. 下回注意吧.. T1 Hunter 解题思路 感 ...

  8. 20210808 Hunter,Defence,Connect

    考场 乍一看都不可做 T1 算了半天样例,一直算出来 \(\frac{81}{400}\),直接丢了 T1 推了推发现是求最长连续 \(0\) 的数量,那就是线段树合并加上<玫瑰花精> T ...

  9. hdu 5779 Tower Defence

    题意:考虑由$n$个结点构成的无向图,每条边的长度均为$1$,问有多少种构图方法使得结点$1$与任意其它节点之间的最短距离均不等于$k$(无法到达时距离等于无穷大),输出答案对$1e9+7$取模.$1 ...

  10. uva 1471 defence lines——yhx

    After the last war devastated your country, you - as the king of the land of Ardenia - decided it wa ...

随机推荐

  1. .NET Conf 2020大会将于2020年11月10日--- 11月12日举行 (UTC)时区

    .NET Conf 2020大会将于2020年11月10日--- 11月12日举行 (UTC)时区 开始时间 2020年11月10日 08:00 (PT) | 16:00 (UTC)| 24:00(北 ...

  2. 计算机网络笔记Part1 概述

    总目录 1.计算机网络的功能.组成.分类 1.1功能 数据通信 资源共享 分布式处理 提高可靠性 负载均衡 1.2组成部分 硬件 软件 协议 1.3分类 按分布范围 广域网 WAN 城域网 MAN 局 ...

  3. C语言复习(六)----typedef 的作用

    typedef的作用 重命名变量:typedef unsigned int Uint;//可以使用Uint代替unsigned int 定义新的数据类型 typedef struct Books{ c ...

  4. 一、Ocelot简单概述

    以下只是本人学习过程的整理 Ocelot官网:http://threemammals.com/ocelot 说明文档:https://ocelot.readthedocs.io/en/latest/ ...

  5. Docker部署ELK之部署kibana7.6.0(2)

    1. 拉取kibana镜像 sudo docker pull kibana:7.6.0 2. 输入命令构建kibana容器,关于挂载kibana配置文件的问题,也可以先构建一个容器,然后把配置文件co ...

  6. Create Shortcut for SSH Hosts

    You frequently visit host 10.0.7.141 for example. It's a waste to type "ssh gcp@10.0.7.141" ...

  7. jd-gui或jad反编译工具bug

    文件1:A.class------------2020-09-01日版本 文件2:A.class------------2020-09-02日版本,代码内容有变动. bug出现条件:文件1或文件2同目 ...

  8. 遗传算法Genetic Algorithm

    遗传算法Genetic Algorithm 好家伙,回回都是这个点,再这样下去人估计没了,换个bgm<夜泊秦淮>,要是经典咏流传能投票选诗词,投票选歌,俺一定选这个 开始瞎叨叨 遗传算法的 ...

  9. 【笔记】偏差方差权衡 Bias Variance Trade off

    偏差方差权衡 Bias Variance Trade off 什么叫偏差,什么叫方差 根据下图来说 偏差可以看作为左下角的图片,意思就是目标为红点,但是没有一个命中,所有的点都偏离了 方差可以看作为右 ...

  10. linux下静态库的制作

     在我们编写软件的过程当中,少不了需要使用别人的库函数.因为大家知道,软件是一个协作的工程.作为个人来讲,你不可能一个人完成所有的工作.另外,网络上一些优秀的开源库已经被业内广泛接受,我们也没有必要把 ...