Solution -「CF 959E」Mahmoud and Ehab and the xor-MST
Description
Link.
一完全图有 \(n\) 个节点 \(0,...,n-1\),其中边 \((i,j)\) 的权值为 \(i\oplus j\),其中 \(\oplus\) 为位异或操作,试求出最小生成树的边权和。
Solution
先从递推的层面考虑.
我们定义 \(F(n)\) 表示结点数为 \(n\) 的答案,也就是最小生成树的边权和.
首先边界条件为 \(F(0)=0,F(1)=1\).
然后我们考虑如何从 \(F(n-1)\) 推到 \(F(n)\).
每当我们新加入一个结点 \(n-1\)(题目结点编号从 0 开始),它的点权为其本身,也就是 \(n-1\),那么此时我们就要从之前的 \(n-1\) 个结点中选出一个点与 \(n-1\) 相连构成当前的最小生成树.
因为边 \((u,v)\) 的边权 \(w(u,v)=u\ \mathrm{xor}\ v\) 且图为完全图,所以我们每加入一个新结点 \(n-1\) 时,所有我们之前的 \(0\cdots n-2\) 号结点都可以被选择.
那么问题转化为:对于一个数 \(n-1\),我们需要选出一个整数 \(x\in[0,n-1)\) 使得 \((n-1)\ \mathrm{xor}\ x\) 最小.
考虑异或运算的定义:每一位相同为零,不同为一.
那么我们选出的 \(x\),需要满足二进制意义下每一位和 \(n-1\) 尽量相同,并且从右到左(也就是二进位从低到高)的第一个不同的位置尽量低.
那么结论就摆在眼前了,我们选择的这个 \(x\) 为 \((n-1)-\mathrm{lowbit}(n-1)\).
为什么?想想 \(\mathrm{lowbit(x)}\) 操作的定义:二进制下 \(x\) 最低的 1 和后面的 0 组成的二进制数.
这样结论的正确性就显然了.
我们 \(F(n)\) 的递推公式为 \(F(n)=F(n-1)+(n\ \mathrm{xor}\ (n\ \mathrm{xor}\ \mathrm{lowbit}(n)))\).
那么暴力递推的代码如下:
(code?)
#include<bits/stdc++.h>
using namespace std;
long long f[100005];
signed main()
{
long long n;
scanf("%lld",&n);
f[0]=0;
f[1]=1;
for(long long i=2;i<n;++i) f[i]=f[i-1]+(i^(i^(i&-i)));
printf("%lld\n",f[n-1]);
return 0;
}
仔细观察一下递推式,\(n\ \mathrm{xor}\ (n\ \mathrm{xor}\ \mathrm{lowbit}(n))\) 不就是 \(\mathrm{lowbit}(n)\) 嘛!
那么为题转化为求 \(\mathrm{lowbit}\) 前缀和.
通过打一个 \(\mathrm{lowbit}\) 表的方法,我们发现 \(\mathrm{lowbit}\) 的值十分有规律,就像这种形式:
\]
其实这种规律要证明也很方便,只要根据二进制数末尾的情况即可得知.
虽然这个规律没啥用,但是启发了我们按位统计贡献的方法在 \(\Theta(1)\) 空间 \(\Theta(\log_{2}n)\) 的时间内计算出了 \(\mathrm{lowbit}\) 前缀和.
具体方法请参考代码.
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
signed main()
{
LL n;
scanf("%lld",&n);
LL ans=0,app=1,low=n;
while(low>1) ans+=app*(low>>1),low-=(low>>1),app<<=1;
printf("%lld\n",ans);
return 0;
}
Solution -「CF 959E」Mahmoud and Ehab and the xor-MST的更多相关文章
- Solution -「CF 1342E」Placing Rooks
\(\mathcal{Description}\) Link. 在一个 \(n\times n\) 的国际象棋棋盘上摆 \(n\) 个车,求满足: 所有格子都可以被攻击到. 恰好存在 \(k\ ...
- Solution -「CF 1622F」Quadratic Set
\(\mathscr{Description}\) Link. 求 \(S\subseteq\{1,2,\dots,n\}\),使得 \(\prod_{i\in S}i\) 是完全平方数,并最 ...
- Solution -「CF 923F」Public Service
\(\mathscr{Description}\) Link. 给定两棵含 \(n\) 个结点的树 \(T_1=(V_1,E_1),T_2=(V_2,E_2)\),求一个双射 \(\varph ...
- Solution -「CF 923E」Perpetual Subtraction
\(\mathcal{Description}\) Link. 有一个整数 \(x\in[0,n]\),初始时以 \(p_i\) 的概率取值 \(i\).进行 \(m\) 轮变换,每次均匀随机 ...
- Solution -「CF 1586F」Defender of Childhood Dreams
\(\mathcal{Description}\) Link. 定义有向图 \(G=(V,E)\),\(|V|=n\),\(\lang u,v\rang \in E \Leftrightarr ...
- Solution -「CF 1237E」Balanced Binary Search Trees
\(\mathcal{Description}\) Link. 定义棵点权为 \(1\sim n\) 的二叉搜索树 \(T\) 是 好树,当且仅当: 除去最深的所有叶子后,\(T\) 是满的: ...
- Solution -「CF 623E」Transforming Sequence
题目 题意简述 link. 有一个 \(n\) 个元素的集合,你需要进行 \(m\) 次操作.每次操作选择集合的一个非空子集,要求该集合不是已选集合的并的子集.求操作的方案数,对 \(10^9 ...
- Solution -「CF 1023F」Mobile Phone Network
\(\mathcal{Description}\) Link. 有一个 \(n\) 个结点的图,并给定 \(m_1\) 条无向带权黑边,\(m_2\) 条无向无权白边.你需要为每条白边指定边权 ...
- Solution -「CF 599E」Sandy and Nuts
\(\mathcal{Description}\) Link. 指定一棵大小为 \(n\),以 \(1\) 为根的有根树的 \(m\) 对邻接关系与 \(q\) 组 \(\text{LCA}\ ...
- Solution -「CF 487E」Tourists
\(\mathcal{Description}\) Link. 维护一个 \(n\) 个点 \(m\) 条边的简单无向连通图,点有点权.\(q\) 次操作: 修改单点点权. 询问两点所有可能路 ...
随机推荐
- Vue3从入门到精通(一)
Vue3简介 Vue3是Vue.js的最新版本,于2020年9月18日正式发布.Vue3相比Vue2有很多改进和优化,包括但不限于: 更快的渲染速度:Vue3通过使用Proxy代理对象和优化虚拟DOM ...
- 公路堵车概率模型Python(Nagel-Schreckenberg交通流模型)
路面上有N辆车,以不同速度向前行驶,模拟堵车问题.有以下假设: 假设某辆车的当前速度是 v 如果 前方可见范围内没车,下一秒车速提高到 v+1 如果 前方有车,前车的距离为 d ,且 d < v ...
- 园子的商业化努力-行行AI人才培养「常青藤计划」
各位园子的小伙伴: 感谢大家长期对园子的支持,AI大模型出现之后,各行各业都在积极思考如何应对,如何把业务场景和AI结合.在这个过程中,AI人才缺乏是最核心的问题. 基于此,园子打算在AI人才培养方面 ...
- @SafeVarargs注解的使用
在声明具有模糊类型(比如:泛型)的可变参数的构造函数或方法时,Java编译器会报unchecked警告.鉴于这些情况,如果程序员断定声明的构造函数和方法的主体不会对其varargs参数执行潜在的不安全 ...
- Hugging News #0616: 有几项非常重要的合作快来围观、最新中文演讲视频回放发布!
每一周,我们的同事都会向社区的成员们发布一些关于 Hugging Face 相关的更新,包括我们的产品和平台更新.社区活动.学习资源和内容更新.开源库和模型更新等,我们将其称之为「Hugging Ne ...
- DevOps|中式土味OKR与绩效考核落地与实践
昨天一个小伙伴和我讨论了一下OKR和绩效管理,所以这次想简单明了地说下在中国怎么做比较合适,很多高大上的理论无法落地也是空中楼阁. 首先说一些,我个人的理解 道德品质和能力素质决定了一个人的职位行为 ...
- Pinot2的开发者社区和教程
目录 文章背景: Pinot 2 是任天堂公司于2018年发布的一款游戏机,采用了基于马里奥兄弟游戏<塞尔达传说:荒野之息>的开放世界操作系统,并推出了许多创新的功能,例如"超级 ...
- (一)centos7下如何搭建Nginx和FastDFS文件管理-环境搭建
一.关于FastDFS 1.FastDFS简介 FastDFS(Fast Distributed File System)是一个开源的分布式文件系统,旨在解决大规模文件存储和访问的问题,例如图片.音视 ...
- 一文了解io包中的discard类型
1. 引言 io.discard是Go语言标准库提供一个结构体类型,其在丢弃不需要的数据场景下非常好用.本文我们将从io.discard 类型的基本定义出发,讲述其基本使用和实现原理,接着简单描述 i ...
- Flutter系列文章-Flutter环境搭建和Dart基础
Flutter是Google推出的一个开源的.高性能的移动应用开发框架,可以用一套代码库开发Android和iOS应用.Dart则是Flutter所使用的编程语言.让我们来看看如何搭建Flutter开 ...