首页 > 其他分享 >「BJOI2017」树的难题 TJ+卡题

「BJOI2017」树的难题 TJ+卡题

时间:2023-05-28 17:14:10浏览次数:41  
标签:颜色 BJOI2017 son lst TJ 权值 卡题 now col

「BJOI2017」树的难题 TJ+卡题

题目大意

  • 给定一棵 \(n\) 个点的树,每条边有颜色,第 \(i\) 种颜色权值为 \(v_i\),共 \(m\) 种颜色。
  • 对于树上一条路径,其权值定义为:经过边的颜色依次组成序列,每个相同颜色段的颜色权值之和。
  • 如:颜色序列 \(1,2,2,1,1,4\),其权值为 \(v_1+v_2+v_1+v_4\)。
  • 给定一对 \(l\),\(r\),求出长度在 \([l,r]\) 内的路径的最大权值。
  • \(1 \le n,m \le 2 \times 10^5,1\le l,r \le n,\mid v_i \mid \le10^4\)。

分析

这道题想清楚了很简单。

首先看到这个路径问题,就往点分治上靠,不是点分树,被骗了吧,哈哈哈

重心下单条链是很好算权值的,关键点在于两条链拼接起来,顶端的贡献问题。

想一想可以发现,其实对于每条链,其他的链顶端只有相同和不相同两种。

那就可以一种颜色一种颜色的处理,就可以很方便地维护相同和不相同的颜色。

所以第一步把儿子都提出来,然后按边的颜色排序。

将相同颜色的贡献用 \(now\) 存储,不同的用 \(lst\) 存储。

依次扫描每个儿子,进行如下操作:

  • 遍历其子树,存下每条链的长度和权值。
  • 查询 \(now\) 和 \(lst\) 中答案。
  • 如果和上个儿子的顶端一样,并入 \(now\);否则将 \(now\) 并入 \(lst\),然后清空 \(now\) 再并入。

现在就是查询的问题了。

如果这条链长度是 \(len\),那么另一半长度就要求在 \([l-len,r-len]\) 内。

显然是一个区间查询问题,因为最值不能容斥,硬上线段树。

然后简单做就行了。

实现细节

首先是一个很关键的答案组成问题。

我们查询线段树的时候,如果长度不是从 \(0\) 开始,就需要将一条链组成答案的情况特判。

这个表现在样例一,但测试数据内没有 hack 这个问题……

写了三天的 lq 不过样例,一怒之下提交 AC。

然后就是线段树区间查询问题,记得跟上下界取 \(\min\) 和 \(\max\)。

线段树涉及到多次清空的问题,动态开点的话可以在新建节点时操作,固定结构的话就用一个 \(lazy-tag\),访问的时候下传标记即可。

还有两棵权值线段树的合并,这个题里面可以直接用 std::vector 存进行过的操作,然后重新插入一次,毕竟多码多错,少码少错,不码不错

Code:

经典的放一半,就问你气不气

实在需要拿去对拍啥的也可以找我,虽然我也想不出怎么找我

    SegmentTree lst,now;//lst 和 now 的作用见上
    std::vector<std::pair<int,long long>> vec;
    std::vector<std::pair<int,long long>> pos;
	//vec 是当前子树,pos 是当前所有同色的子树
    std::vector<edge> son;//存儿子
    void work_calc(int u,int fa,int col,int dep,long long dis){
        vec.emplace_back(dep,dis);//递归计算深度与权值
        for(edge e:G[u])
            if(!vis[e.ver]&&e.ver!=fa)
                work_calc(e.ver,u,e.col,dep+1,dis+(e.col==col?0:val[e.col]));
    }
    void solve(int u){
        vis[u]=1;
        son.clear();
        for(edge e:G[u])
            if(!vis[e.ver])
                son.emplace_back(e);
        std::sort(son.begin(),son.end(),[](edge x,edge y)->bool{
            return x.col<y.col;
        });//排序
        //lambda 表达式,https://oi-wiki.org/lang/lambda/ 有介绍
        int lst_col={-1};//上一个颜色
        lst.init(all);//链的长度不会超过根的 size
        now.init(all);
        pos.clear();
        for(auto e:son){
            if(~lst_col){
                vec.clear();
                work_calc(e.ver,u,e.col,1,val[e.col]);//计算链
                if(e.col==lst_col){//颜色相同
                    for(auto it:vec)
                        ans=std::max({ans,l<=it.first&&it.first<=r?it.second:-Inf,lst.query(l-it.first,r-it.first)+it.second,now.query(l-it.first,r-it.first)+it.second-val[e.col]});//查询
                    for(auto it:vec)
                        now.updata(it.first,it.second),pos.emplace_back(it.first,it.second);//更新
                }
                else{//新颜色
                    for(auto it:pos)
                        lst.updata(it.first,it.second);//此时之前的 now 等效于 lst
                    pos.clear();
                    now.init(all);
                    for(auto it:vec)
                        ans=std::max({ans,l<=it.first&&it.first<=r?it.second:-Inf,lst.query(l-it.first,r-it.first)+it.second});
                    for(auto it:vec)//清空后的新数据
                        now.updata(it.first,it.second),pos.emplace_back(it);
                }
                lst_col=e.col;
            }
            else{//特殊处理第一棵
                vec.clear();
                work_calc(e.ver,u,e.col,1,val[e.col]);
                for(auto it:vec)
                    ans=std::max(ans,l<=it.first&&it.first<=r?it.second:-Inf);
                for(auto it:vec)
                    now.updata(it.first,it.second),pos.emplace_back(it);
                lst_col=e.col;
            }
        }
        //...递归继续处理
    }

标签:颜色,BJOI2017,son,lst,TJ,权值,卡题,now,col
From: https://www.cnblogs.com/LQ636721/p/17438486.html

相关文章

  • FastJson
          ......
  • React18+TS+NestJS+GraphQL全栈开发示例
    React18+TS+NestJS+GraphQL全栈开发示例全栈开发是指一位开发人员可以熟练掌握前端、后端和数据库等多个领域的技术,能够完整地开发一个应用程序。在本文中,我们将介绍如何使用React18+TS+NestJS+GraphQL这个技术组合来进行全栈开发。技术选型在开始开发之前,我们需要选择合适的技术栈......
  • Fastjson 很快,但不适合我....
    作者:nyingping来源:juejin.cn/post/7215886869199863869记者:大爷您有什么特长呀?FastJson:我很快。记者:23423乘以4534等于多少?FastJson:等于2343.记者:??FastJson:你就说快不快吧!这个略显马丽苏的标题,各位看官将就着看吧。主要是怕被喷。FastJson真的很好,我用不用我喜不......
  • tj-factory_Person_v1_to_v2.py
    说明:该脚本把21的mysql数据库factory_cloud.personnel表里的数据迁移到185的mysql数据库tj_factory_prod.bd_person表里,这2个表字段不一致,只要2个表相关联的字段。 importpymysqlimportsysimportdatetimefromtimeimportstrftime##################在21找出人员数据#......
  • 一文读懂面试官都在问的Fastjson漏洞
    Fastjson1.2.24-RCE漏洞漏洞简介fastjson是阿里巴巴的开源JSON解析库,它可以解析JSON格式的字符串,支持将JavaBean序列化为JSON字符串,也可以从JSON字符串反序列化到JavaBean。即fastjson的主要功能就是将JavaBean序列化成JSON字符串,这样得到字符串之后就可以通过数据库等方式......
  • 是什么让你的ExtJS应用程序运行缓慢?
          本文说的“缓慢”,是只运行时的缓慢,而不是只加载资源的时间。      在过去的一年半以来,我一直与RobertBosch在Bosch软件创新公司工作,在那里我们的前端技术堆栈非常依赖ExtJS。我有机会开发VisualRulesWebModeler机器协助开发其它几个基于ExtJS的应用,因此,我......
  • ExtJS 4中动态加载的路径设置
         在此首先感谢的文顺网友,是他提醒了我需要写这文的。     在Loader对象中,动态加载是使用getPath方法获取下载路径的,其代码如下:1 getPath: function(className) {2     var path = '',3         paths =......
  • 【译】ExtJS 4.1会带来什么
    原文:http://www.sencha.com/blog/whats-new-in-ext-js-4-1/渲染和布局。虽然我们的大多数时间一直致力于这项努力,但也有很多其他方法的进展可以分享。这些改进当中,主要的改进包括Grid、BorderLayout和海王星主题预览这些内容。     性能要成功地和永久地提高性能,测量已成为......
  • ExtJS应用架构设计(三)
    原文:http://www.sencha.com/learn/architecting-your-app-in-ext-js-4-part-3/?mkt_tok=3RkMMJWWfF9wsRonuKrLZKXonjHpfsX56uolXaS2lMI%2F0ER3fOvrPUfGjI4AT8t0dvycMRAVFZl5nR9dFOOdfQ%3D%3D      在该系列文章的前两篇文章中(一、二),我们探讨了如何使用ExtJS4的新特性构建一......
  • ExtJS应用架构设计(二)
    原文:http://www.sencha.com/learn/architecting-your-app-in-ext-js-4-part-2/      在《ExtJS应用架构设计》一文,我们探讨了如何使用ExtJS构建一个潘多拉风格的应用程序。我们采用了MVC架构,并将它应用到一个比较复杂的用户界面,应用中带有多个视图和模型。在这篇文章中,我......