WEASELTX code
给你一棵 n 个节点的有根树(节点),以及每个节点 i 的初始权值 a[i] 。
一次操作则是指将每个节点的权值变为以其为根的子树中所有节点的权值之异或和。
维护 q 个询问,每个询问则是问 T 次操作之后,根节点的权值。
解:
相关题目:HDU 6129 http://acm.hdu.edu.cn/showproblem.php?pid=6129
HDU 6129 是树退化成一条链的情形。

我们的做法依然是考虑每个节点对答案的贡献。
如果是求和,则 T 次操作之后,考虑每个节点 i 对答案的贡献,结果为
$$\sum_{i} \binom{T+d[i]-1}{d[i]} a[i],$$
其中 d[i] 是节点 i 的深度(根节点深度为 0 ),额外定义$\binom{-1}{0} = 1$。

而对于异或和,我们只需要考虑系数模 2 的余数即可,上式可变为
$$\bigoplus_{i} \left( \binom{T+d[i]-1}{d[i]} \bmod 2 \right) a[i].$$

剩下我们要考虑 $\binom{a+b}{b} \bmod 2 = 1$ 的充要条件。
由 Lucas 定理,可得 $\binom{a}{b} \bmod 2 = 1$ 当且仅当 $a \operatorname{and} b = b$ 。
从而,$\binom{a+b}{b} \bmod 2 = 1$ 当且仅当 $(a+b) \operatorname{and} b = b$ ,即$a \operatorname{and} b = 0$(不是那么显然,需要读者自行证一下)。

观察式子可以发现,设$2^k > \max_i \{d[i]\}$,则 $T$ 次操作后的结果与 $T \bmod 2^k$ 次操作后的结果相同。
因此我们可以只考虑 $0 \le T < 2^k$ 的情况。

注意到 $\binom{T+d[i]-1}{d[i]} \bmod 2 = 1$ 当且仅当 $(T-1) \operatorname{and} d[i] = 0$。
于是我们先把所有节点按照其深度分组,同一个深度的节点先合并在一块,因为他们在参与运算时一定是捆绑在一起的。
接着根据 $(T-1)$,我们依次枚举满足条件的 $d[i]$ ,这是一个经典的子集枚举,即枚举 ~(T-1) 的子集。
枚举 s 的子集的方式为

  1. for (int x = s; x; x = (x-)&s)
  2. {
  3. // we have enumerated every x satisfying x&s = x.
  4. }

由于 T 会取遍 $[0, 2^k)$ 之间的值,这样对每个 T 都枚举一遍子集的时间复杂度为 $O(3^k)$ (不是那么显然,需要读者自行证明)。
而 $k = O(\log n)$,于是,总的时间复杂度为 $ O(3^{\log n}) $。

Codechef WEASELTX的更多相关文章

  1. Codechef SEPT17

    Codechef SEPT17 比赛链接:https://www.codechef.com/SEPT17 CHEFSUM code给定数组 a[1..n] ,求最小的下标 i ,使得 prefixsu ...

  2. 【BZOJ-3514】Codechef MARCH14 GERALD07加强版 LinkCutTree + 主席树

    3514: Codechef MARCH14 GERALD07加强版 Time Limit: 60 Sec  Memory Limit: 256 MBSubmit: 1288  Solved: 490 ...

  3. 【BZOJ4260】 Codechef REBXOR 可持久化Trie

    看到异或就去想前缀和(⊙o⊙) 这个就是正反做一遍最大异或和更新答案 最大异或就是很经典的可持久化Trie,从高到低贪心 WA: val&(1<<(base-1))得到的并不直接是 ...

  4. codechef 两题

    前面做了这场比赛,感觉题目不错,放上来. A题目:对于数组A[],求A[U]&A[V]的最大值,因为数据弱,很多人直接排序再俩俩比较就过了. 其实这道题类似百度之星资格赛第三题XOR SUM, ...

  5. codechef January Challenge 2014 Sereja and Graph

    题目链接:http://www.codechef.com/JAN14/problems/SEAGRP [题意] 给n个点,m条边的无向图,判断是否有一种删边方案使得每个点的度恰好为1. [分析] 从结 ...

  6. BZOJ3509: [CodeChef] COUNTARI

    3509: [CodeChef] COUNTARI Time Limit: 40 Sec  Memory Limit: 128 MBSubmit: 339  Solved: 85[Submit][St ...

  7. CodeChef CBAL

    题面: https://www.codechef.com/problems/CBAL 题解: 可以发现,我们关心的仅仅是每个字符出现次数的奇偶性,而且字符集大小仅有 26, 所以我们状态压缩,记 a[ ...

  8. CodeChef FNCS

    题面:https://www.codechef.com/problems/FNCS 题解: 我们考虑对 n 个函数进行分块,设块的大小为S. 每个块内我们维护当前其所有函数值的和,以及数组中每个元素对 ...

  9. codechef Prime Distance On Tree(树分治+FFT)

    题目链接:http://www.codechef.com/problems/PRIMEDST/ 题意:给出一棵树,边长度都是1.每次任意取出两个点(u,v),他们之间的长度为素数的概率为多大? 树分治 ...

随机推荐

  1. js时间戳和时间格式之间的转换

    //时间戳转换成日期时间2014-8-8 下午11:40:20 function formatDate(ns){ return new Date(parseInt(ns) * 1000).toLoca ...

  2. php 中函数获取可变参数的方法, 这个语法有点像 golang 语言中的

    原文呢:http://php.net/manual/en/functions.arguments.php#functions.arguments.type-declaration.strict Onl ...

  3. js中有包装类,java中也有包装类

    new Number() vs Number() What is the difference between new Number() and Number()? I get that new Nu ...

  4. SolidWorks如何绘制抽壳零件

    1 绘制一个零件,点击抽壳   2 你可以一个一个面选,也可以直接选中一个零件,对他的所有面都薄壳处理(右击弹出菜单选择确定即可)   3 可以用剖视图检查是否抽壳成功   4 对于复杂的零件,一个一 ...

  5. 微信小程序 - 音频播放(1.2版本和1.2版本之后)

    不多说了,直接贴code // 1.2版本以后便不在维护 wx.getBackgroundAudioManager({ success:function(res){ var status =res.s ...

  6. 横跨十年CPU架构回顾

    http://cpu.zol.com.cn/209/2092791_all.html#p2092791 本文导航 第1页:K7架构 打开AMD崛起大门的钥匙 第2页:玩破解 K7时代便已经拥有 第3页 ...

  7. iOS 相似淘宝商品详情查看翻页效果的实现

    基本思路: 1.设置一个 UIScrollView 作为视图底层,而且设置分页为两页 2.然后在第一个分页上加入一个 UITableView 而且设置表格可以上提载入(上拉操作即为让视图滚动到下一页) ...

  8. linux输入子系统(5) - 学习框架

    注:本系列转自: http://www.ourunix.org/post/290.html input子系统学习系列文章,是我在实际开发过程中遇到也是必须啃下去的第一个Linux驱动,所以有必要记载下 ...

  9. shell学习五十六天----延迟进程调度

    延迟进程调度 前言:大部分时候,我们都希望进程快点開始,开点结束,别卡.而shell的运行,也是在前一个命令后,立即接着运行下一个命令.命令完毕的速度是与资源的限制有关,且不在shell的权限下. 在 ...

  10. Chrome浏览器 js 关闭窗口失效解决方法

    //获取元素ID var DelHtml = document.getElementById("imgdel"); //alert(DelHtml); //添加点击事件 DelHt ...