首页 > 其他分享 >CF908E New Year and Entity Enumeration 题解

CF908E New Year and Entity Enumeration 题解

时间:2024-08-09 20:06:18浏览次数:16  
标签:题解 Enumeration leq cdots dp CF908E 集合 sim

CF908E

给定 \(m\),令 \(M = 2^m -1\)。给定 \(\{0,1,\cdots, M\}\) 的大小为 \(n\) 的子集 \(T\),定义集合 \(T \subseteq S \subseteq \{0,1,\cdots,M\}\) 是好的当且仅当:

  • \(a \in S \Rightarrow a \oplus M \in S\)

  • \(a,b \in S \Rightarrow a\ and\ b \in S\)

求好的集合的个数

\(1 \leq m \leq 1000, 1 \leq n \leq min(2^m, 50)\)

  • 我们先考虑假如得到了一个不完整的 \(S\) 如何把他变为合法的集合

  • 打表找规律

  • 可以发现当加入了 0001100111 后,他会把 54 分成一部分, 3 一部分,21 一部分,然后填 0/1,答案是:

  • 00000
    00011
    00100
    00111
    11000
    11011
    11100
    11111
    
  • 可以发现,若 \(S\) 中的 \(x_1,x_2,\cdots,x_t\)​ 位在所有数中要么同为 \(1\),要么同为 \(0\),也就是说相同,那么他们就会”打包“在一起,在 \(S\) 中独立取 \(0/1\)

  • 其实这不是巧合,这是有依据的

  • 第一条操作的意思显然就是 \(a \in S \Rightarrow (\sim a) \in S\)

  • 而我们有:

  • \[\begin{align} & a\ or\ b = \sim((\sim a)\ and\ (\sim b)) \\ & a \oplus b = \sim((\sim(a\ or\ b)\ or\ (a\ and\ b)) \end{align} \]

  • 因此上述的操作最终制造出了一个异或操作,即这些数构成了一个异或的线性基

  • 因此我们只需要按位进行集合划分

  • 设 \(dp_i\) 表示 \(i\) 位数,拆开 or 不拆开的所有方案数,有转移:

  • \[dp_i \leftarrow \sum_{j=0}^{i-1} \binom{i-1}{j} dp_{i-j-1} \]

  • 大致意思是考虑第 \(i\) 位数和另外 \(i-1\) 个位置中 \(j\) 个位置划分成一个集合,然后继续递归

  • 最后只需要根据乘法原理相乘即可

  • 最终复杂度为 \(O(m^2+mn)\)

标签:题解,Enumeration,leq,cdots,dp,CF908E,集合,sim
From: https://www.cnblogs.com/fox-konata/p/18351414

相关文章

  • 题解:CF1209E1 Rotate Columns (easy version)
    题目传送门题意给出一个\(n\timesm\)的矩阵,我们可以对每一列进行循环位移,不限次数,最后求每一行的最大值之和。\(1\leqn\leq4,1\leqm\leq100\)思路注意到\(n\)的范围很小,那么我们也可以缩小\(m\)的范围。正确的方案显然是取整个矩阵的前\(n\)大值,并且将它......
  • CF1647F Madoka and Laziness 题解
    CF1647F给定排列\(p\),将其划分为两个单峰子序列,求两个单峰子序列的峰的组合的情况数。\(2\leqn\leq5\times10^5\)首先要注意到一个非常常见的地方:两个单峰子序列中的一个的峰值一定在整个排列\(p\)的最大值处这个非常显然,但并不注意到他的重要性,容易被忽视为......
  • luogu题解:P10456 The Pilots Brothers' refrigerator【缺少 SPJ】
    思路此题题意酷似P10449.费解的开关。https://www.luogu.com.cn/problem/P10449不同之处便是状态连锁改变不同,但做法截然不同,此题是一个\(4\times4\)的矩阵。暴力枚举的复杂度是\(O(10^7)\),即\(2^{16}\times16\times16=16777216\),\(10^7\)的复杂度可以通......
  • P2901题解
    题目大意输出一张有向带权图前k短路的长度思路分析这是道k短路板子题我们可以用Astar算法来实现它OIwiki相关算法的网页简单来讲,Astar定义了一个估值函数f(x)=g(x)+h(x)g(x)表示由起点到达x点的路程(不一定是最短路),而h(x)则是终点到x点的最短路程这个估值函数可以预估从该......
  • Codeforces 165E Compatible Numbers 题解
    思路高维前缀和高维前缀和把数的二进制看成一个集合,二进制的每一位为\(1\)为全集\(V\)。根据题目描述,若两数\(a,b\)相容,则\(a\operatorname{and}b=0\),容易发现,\(b\in\complement_{V}a\),所以我们只需要用高维前缀和处理出\(\complement_{V}a\)的一个元素即可。......
  • ABC349D题解
    [ABC349D]DivideInterval题解传送门:luogu|atcoder题目简述给定非负整数\(l\)和\(r\)(\(l<r\)),令\(S(l,r)\)表示序列\((l,l+1,\ldots,r-2,r-1)\),其中包含从\(l\)到\(r-1\)的所有整数。此外,一个序列被称为“好序列”,当且仅当它可以表示为\(S(2^ij,2^{i}(j+1))\),......
  • AT_past202010_m 筆塗り 题解
    题目传送门前置知识线段树|树链剖分解法观察到要维护树上信息,且更改的呈链状,考虑进行树链剖分。将边权转化成点权,钦定边权给了深度更深的那个点,注意更新时不能更新\(\operatorname{LCA}\)。区间赋值和单点查询用线段树维护即可。代码#include<bits/stdc++.h>usingnam......
  • 如何避免自己问题解决缓慢导致项目周期延长
    在公司实习期间,我发现自己对业务的熟悉程度不足,导致在预期时间和实际完成时间上存在差异。虽然这种情况在后期有所改善,但前期的压力相对较大。为此,我总结了以下几点经验和改进措施:1.问题描述与现有分析我们今天的工作进展如何?当前诊断的调查进展如何?如果进展缓慢,是什么原因?需......
  • ABC349D题解
    [ABC349D]DivideInterval题解传送门:luogu|atcoder题目简述给定非负整数$l$和$r$($l<r$),令$S(l,r)$表示序列$(l,l+1,\ldots,r-2,r-1)$,其中包含从$l$到$r-1$的所有整数。此外,一个序列被称为“好序列”,当且仅当它可以表示为$S(2^ij,2^{i}(j+1))$,其中$i$和$j$......