Tree XOR
引理:对一个点最多只会操作一次
证明:如果对一个点操作了多次,不妨设每次操作的数是
思路一:充分利用异或的无顺序性
对任意一种方案,我们的操作顺序是从儿子往父亲依次操作,这样的话,在即将操作点
于是我们设
然后再换根DP即可
思路二:位运算的经典的按位考虑
仍然利用引理,设一个点在最终的方案中被操作的数为
假设当前考虑的是第
于是仍然可以设计一个换根DP,跑出以
引理:对一个点最多只会操作一次
证明:如果对一个点操作了多次,不妨设每次操作的数是
思路一:充分利用异或的无顺序性
对任意一种方案,我们的操作顺序是从儿子往父亲依次操作,这样的话,在即将操作点
于是我们设
然后再换根DP即可
思路二:位运算的经典的按位考虑
仍然利用引理,设一个点在最终的方案中被操作的数为
假设当前考虑的是第
于是仍然可以设计一个换根DP,跑出以
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构