闲扯

最近有点颓,都修到好晚,早上起来和吔shi一样难受

忍着困意把题面看完,发现啥也不会,又是一场写暴力的模拟赛

T1发现似乎可以DP,顺手码了个

T2像个最小瓶颈路板子,但是只做过N^2算法的...

T3我是真的傻,估计全场就我一人以为只能往前跳于是写了个DP

结果30+35+0

然后发现T1爆了,后面都输出负数,全部用long long 后交了发,居然95?!wtf

后面发现最naiive的贪心都有90,这数据比联赛还水啊,后面发现只有一个点的一次询问答案不一样,打个表就A了

T1 colour

gu

T2 graph

一看就发现这种边就是最小瓶颈路(边),根据最小生成树也是最小瓶颈生成树的性质,我们可以在最小生成树上DFS求到所有点对的最小瓶颈路.

但怎么找符合条件的点对?对于L=0的子任务,我们可以在Kruskal过程中每新加入一条边就计算两个联通块大小的乘积,由于我们的边是从小到大排序的,这条新加入的边一定是这两个联通块点对之间的最小瓶颈路

正解使用了Kruskal重构树,不了解的先去学习一下(我也是做这题才学的)

容易发现,两个原树上的点在重构树上的LCA的点权就是两点间的最小瓶颈路长度,这样只需要求一个LCA的时间复杂度就可以得到两点之间的最小瓶颈路

然后运用启发式合并的思路,我们可以枚举原树上的每一条边计算它的贡献,然后进入重构树上对应点相邻的两棵子树中较小的那一棵枚举点,这样就能得到了两个约束条件:一个是DFS序的约束(因为另一个点必须在另一棵较大的子树中),一个是颜色范围的约束

又转化成并不喜闻乐见的二维数点问题,离线+树状数组+二维前缀和即可

然后发现WA了,xxzh大佬说要注意l=0的情况,改后又RE了,交了几发终于A了...不过跑得好慢

其实这题一开始想线段树合并的,但是没有想到启发式合并,晚上有大佬提供线段树合并的思路就是每个联通块维护权值线段树,Kruskal连一条边的时候,进入较小的块枚举然后在另一棵树上线段树查询

这样的话也是两个log

/*
code by RyeCatcher
*/
inline char gc(){
static char buf[SIZE],*p1=buf,*p2=buf;
return p1==p2&&(p2=(p1=buf)+fread(buf,1,SIZE,stdin),p1==p2)?EOF:*p1++;
}
template <class T>inline void read(T &x){
x=0;int ne=0;char c;
while((c=gc())>'9'||c<'0')ne=c=='-';x=c-48;
while((c=gc())>='0'&&c<='9')x=(x<<3)+(x<<1)+c-48;x=ne?-x:x;return ;
}
const int maxn=600005;
const int inf=0x7fffffff-10;
int n,m,l,c[maxn],mx_c=0;
struct Nico{
int x,y,dis;
bool operator <(const Nico &rhs)const{
return dis<rhs.dis;
}
}nico[maxn];
int pa[maxn];
int get(int x){return (pa[x]==x)?(pa[x]):(pa[x]=get(pa[x]));}
int cnt=0,w[maxn<<1],fa[maxn<<1],ch[maxn<<1][2],size[maxn<<1];
int dfn[maxn<<1],tot=0,ed[maxn<<1];
ll sum[maxn<<3],qry[maxn];
inline void add(int x,int d){for(;x<=2*n-1;x+=x&(-x))sum[x]+=d;}
inline ll query(int x){ll tmp=0;for(;x>=1;x-=x&(-x))tmp+=sum[x];return tmp;}
struct QAQ{
int x,y,d,id;
bool operator <(const QAQ & rhs)const{
return (x==rhs.x)?id<rhs.id:x<rhs.x;
}
}qwq[maxn*25];int num=0;
void pre_dfs(int now){
int v;
dfn[now]=++tot,size[now]=1;
//printf("--%d %d--\n",now,fa[now]);
if(ch[now][0])pre_dfs(ch[now][0]);
if(ch[now][1])pre_dfs(ch[now][1]);
size[now]+=(size[ch[now][0]]+size[ch[now][1]]);
ed[now]=tot;
if(now>=1&&now<=n){
qwq[++num]=(QAQ){c[now],dfn[now],1,0};
//printf("%d %d\n",dfn[now],c[now]);
}
return ;
}
int L,R,LL,RR;
void dfs(int now,int id){
int v;
if(ch[now][0])dfs(ch[now][0],id);
if(ch[now][1])dfs(ch[now][1],id);
//LL=max(0,c[now]-l),RR=min(c[now]+l,mx_c);
if(now>n||now<1)return ;
LL=c[now]-l,RR=c[now]+l;if (!l) RR++;
qwq[++num]=(QAQ){-inf-1,L-1,1,id};
qwq[++num]=(QAQ){-inf-1,R,-1,id};
qwq[++num]=(QAQ){LL,L-1,-1,id};
qwq[++num]=(QAQ){LL,R,1,id};
qwq[++num]=(QAQ){RR-1,L-1,1,id};
qwq[++num]=(QAQ){RR-1,R,-1,id};
qwq[++num]=(QAQ){inf,L-1,-1,id};
qwq[++num]=(QAQ){inf,R,1,id};
//printf("%d %d %d %d %d %d\n",now,L,R,LL,RR,id);
return ;
}
int main(){
//freopen("graph19.in","r",stdin);
FO(graph);
int x,y,z;
read(n),read(m),read(l);
for(ri i=1;i<=n;i++)pa[i]=i,read(c[i]),mx_c=max(mx_c,c[i]);
for(ri i=n+1;i<=n*2+2;i++)pa[i]=i;
for(ri i=1;i<=m;i++){
read(x),read(y),read(z);
nico[i]=(Nico){x,y,z};
}
std::sort(nico+1,nico+1+m);
cnt=n;
for(ri i=1;i<=m;i++){
x=nico[i].x,y=nico[i].y;
x=get(x),y=get(y);
if(x==y)continue;
pa[x]=++cnt,pa[y]=cnt;
fa[x]=cnt,fa[y]=cnt,ch[cnt][0]=x,ch[cnt][1]=y;
w[cnt]=nico[i].dis;
//printf("%d %d()()()\n",cnt,w[cnt]);
if(cnt==2*n-1)break;
}
fa[cnt]=0;
pre_dfs(cnt);
//for(ri i=1;i<=cnt;i++)printf("--%d %d %d %d %d %d--\n",i,fa[i],ch[i][0],ch[i][1],dfn[i],ed[i]);
for(ri i=n+1;i<=cnt;i++){
x=ch[i][0],y=ch[i][1];
if(size[x]>size[y])std::swap(x,y);
L=dfn[y],R=ed[y];
//printf("**%d %d %d %d\n",i,L,R,w[i]);
dfs(x,i);
}
std::sort(qwq+1,qwq+1+num);
for(ri i=1;i<=num;i++){
if(qwq[i].id==0){
//printf("%d %d\n",qwq[i].y,qwq[i].d);
add(qwq[i].y,1);
}
else{
//printf("%d %d %lld %d %d\n",qwq[i].id,qwq[i].d,query(qwq[i].y),qwq[i].x,qwq[i].y);
qry[qwq[i].id]+=qwq[i].d*query(qwq[i].y);
}
}//return 0;
ll ans=0;
//for(ri i=n+1;i<=cnt;i++)printf("&&&%d %d\n",i,w[i]);
for(ri i=n+1;i<=cnt;i++){
//printf("%d %d %d\n",i,qry[i],w[i]);
ans+=qry[i]*w[i];
}
printf("%lld\n",ans);
return 0;
}

[NOIP2018模拟赛10.25]瞎搞报告的更多相关文章

  1. [NOIP2018模拟赛10.16]手残报告

    [NOIP2018模拟赛10.16]手残报告 闲扯 炉石乱斗模式美滋滋啊,又颓到好晚... 上来T2先敲了树剖,看T1发现是个思博DP,然后没过大样例,写个暴力发现还是没过大样例!?才发现理解错题意了 ...

  2. [NOIP2018模拟赛10.18]自闭报告

    闲扯 这一天,菜鸡RyeCatcher又想起来了被毒瘤题支配的恐惧 今天比较好玩,还是ljy提醒才发现文件夹里有题面...不知道外面的人什么时候才发现 看完了题面,又回到了雅礼啥题也不会写的感觉 T1 ...

  3. [NOIP2018模拟赛10.22]咕咕报告

    闲扯 这是篇咕咕了的博客 考场上码完暴力后不知道干什么,然后忽然发现这个T1好像有点像一道雅礼集训时讲过的CF题目 Rest In Shades ,当时那道题还想了挺久不过思路比较妙,于是我就也\(y ...

  4. [NOIP2018模拟赛10.20A]挂分报告

    闲扯 先看看了B组,T1 ZROI刚好讲过一个性质原根一般很小的,直接枚举;T2一眼二分然后似乎状压 T3没看 然后上来A组题,T1 flow这名字...网络流?! T1题面非常的社会主义核心价值观, ...

  5. [NOIP2018模拟赛10.23]发呆报告

    闲扯 考场看了眼题目感觉很难,一个小时敲完了所有暴力...嗯然后就在那里发呆什么事也没做 T3考场上把数据结构想了个遍都不会完成1操作,现在看这种思路其实之前也接触过... 比较玄学的一件事情就是T1 ...

  6. [NOIP2018模拟赛10.19]只会暴力报告

    闲扯 今天又是暴力满满(并不)的一天呢 昨天老师说了分数要正态分布,今天看起来...不过暴力分很多,虽然我人太傻逼又没打满 T1 woc?不是说送分的吗,看起来又是个树形DP神题,暴力告辞,链上的搞一 ...

  7. NOIP2017提高组模拟赛 10 (总结)

    NOIP2017提高组模拟赛 10 (总结) 第一题 机密信息 FJ有个很奇怪的习惯,他把他所有的机密信息都存放在一个叫机密盘的磁盘分区里,然而这个机密盘中却没有一个文件,那他是怎么存放信息呢?聪明的 ...

  8. EZ 2018 06 10 NOIP2018 模拟赛(十八)

    好久没写blog&&比赛题解了,最近补一下 这次还是很狗的,T3想了很久最后竟然连并查集都忘写了,然后T2map莫名爆炸. Rating爆减......链接不解释 好了我们开始看题. ...

  9. NOIP2018 模拟赛(二十二)雅礼NOI

    Preface 这次的题目都是NOI+的题,所以大家的分数都有点惨烈. 依靠T1大力骗分水到Rank2 所以想看正解的话看这里吧 A. 「雅礼NOI2018模拟赛(一) Day1」树 看一眼题目感觉十 ...

随机推荐

  1. redis启动、关闭脚本

    #!/bin/bash PORT= NAME=redis-server ID=`ps -ef | grep "$NAME" | grep -v "grep" | ...

  2. LiquiBase实战总结

    LiquiBase概述 Liquibase是一个用于跟踪.管理和应用数据库变化的开源的数据库重构工具.它将所有数据库的变化(包括结构和数据)都保存在XML文件中,便于版本控制. Liquibase具备 ...

  3. Golang基础笔记

    <基础> Go语言中的3个关键字用于标准的错误处理流程: defer,panic,recover. 定义一个名为f 的匿名函数: Go 不支持继承和重载. Go的goroutine概念:使 ...

  4. Docs-.NET-C#-指南-语言参考-预处理器指令:#undef(C# 参考)

    ylbtech-Docs-.NET-C#-指南-语言参考-预处理器指令:#undef(C# 参考) 1.返回顶部 1. #undef(C# 参考) 2018/06/30 #undef 允许你定义一个符 ...

  5. 一百四十四:CMS系统之评论布局和功能二

    在base页加一个登录标识符 给加页面两个id,方便取值 js $(function () { //初始化ueditor var ue = UE.getEditor('editor', { 'serv ...

  6. 关于Selenium remote模式分布式执行UI自动化测试必定面临的性能问题

    1.大部分自动化测试人员都是在本地执行UI自动化测试,也就是代码和浏览器必须在同一台机器上,这样的的缺陷很多,无法多任务并发执行UI自动化测试用例,效率极低 2.正是如此,Selenium 的remo ...

  7. using kafkacat reset kafka offset

    1. install kafkacat Ubuntu apt-get install kafkacat CentOS install deepenency yum install librdkafka ...

  8. 创建IDOC

    第一步:WE31 创建IDOC所包含的字段. 第二步:WE30 创建IDOC 把Segment分配给IDOC 第三步:WE81 创建信息类型 第四步:WE82 把IDOC类型与信息类型对应. 第五步: ...

  9. AWS 存储服务(三)

    目录 AWS S3 业务场景 挑战 解决方案 S3的好处 S3 属性 存储桶 Buckets 对象 Object S3 特性 S3 操作 可用性和持久性 一致性 S3 定价策略 S3高级功能 存储级别 ...

  10. leetcode834 Sum of Distances in Tree

    思路: 树形dp. 实现: class Solution { public: void dfs(int root, int p, vector<vector<int>>& ...