枚举子集dp

枚举子集

二进制枚举子集下面代码就是枚举的s的子集(二进制状态压缩)

	for(int i=s;i;i=(i-1)&s){//i表示的就是s的子集}

枚举所有子集的子集的时间复杂度
比如一个有n个元素构成的集合,子集的数量是2n2^n2n,现要求枚举所有子集的子集。
一个有k个元素构成的集合,子集的数量是2k2^k2k

考虑nnn个元素构成的集合子集:
元素个数是000的集合个数是Cn0C_n^0Cn0
元素个数是111的集合个数是Cn1C_n^1Cn1
…\dots
于是有以下等式
Cn0×20+Cn1×2n+⋯+Cnn×2n=(1+2)n=3nC_n^0×2^0+C_n^1×2^n+\dots+C_n^n×2^n=(1+2)^n=3^nCn0×20+Cn1×2n++Cnn×2n=(1+2)n=3n

由此最终需要枚举3n3^n3n个状态,时间复杂度为Θ(3n)\Theta(3^n)Θ(3n)

Close Group

首先暴力预处理出所有满足题意的连通块,连通块中的点两两之间有直接边。Θ(n2+2n)\Theta(n^2+2^n)Θ(n2+2n)

状态压缩dp
状态表式:fif_ifi表示选择iii这些点构成的最少数量的团
状态计算:枚举iii状态的子集jjj,于是有fi=min(fi,fj+fi⊕j)f_i=min(f_i,f_j+f_{i\oplus j})fi=min(fi,fj+fij)
时间复杂度:枚举所有状态的子集即上述证明Θ(3n)\Theta(3^n)Θ(3n)

时间复杂度Θ(n2+2n+3n)\Theta(n^2+2^n+3^n)Θ(n2+2n+3n)

318=3874204893^{18}=387 420 489318=387420489差不多能过,谁让状态压缩就是那么玄学呢

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<iostream>
#include<algorithm>
using namespace std;
const int N=20;
bool ok[1<<N];
int g[N][N];
int dp[1<<N];
int main()
{IO;int T=1;//cin>>T;while(T--){int n,m;cin>>n>>m;while(m--){int a,b;cin>>a>>b;--a,--b;g[a][b]=g[b][a]=1;}for(int i=0;i<1<<n;i++){vector<int> t;for(int j=0;j<n;j++)if(i>>j&1) t.push_back(j);ok[i]=1;for(int j=0;j<t.size();j++)for(int k=j+1;k<t.size();k++)if(!g[t[j]][t[k]]) ok[i]=0;}for(int i=0;i<1<<n;i++) dp[i]=n+1;dp[0]=0;for(int i=1;i<1<<n;i++){if(ok[i]) dp[i]=1;for(int j=i;j;j=(j-1)&i)dp[i]=min(dp[i],dp[j]+dp[j^i]);}cout<<dp[(1<<n)-1]<<'\n';}return 0;
}

E - Or Plus Max

对于K的子集一定满足iorj≤Ki\ or\ j\leq Ki or jK
枚举子集,记录子集的最大值和次大值,相加即可

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<iostream>
#include<algorithm>
using namespace std;
const int N=500010;
int a[N];
int mx[N],f[N];
int main()
{IO;int T=1;//cin>>T;for(int ca=1;ca<=T;ca++){int n;cin>>n;for(int i=0;i<1<<n;i++){cin>>a[i];mx[i]=a[0];}for(int i=0;i<1<<n;i++)for(int j=i;j;j=(j-1)&i){f[i]=max(f[i],a[j]+mx[i]);mx[i]=max(mx[i],a[j]);}for(int i=1;i<1<<n;i++) {f[i]=max(f[i-1],f[i]);cout<<f[i]<<'\n';}}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319194.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

数列互质(莫队算法)

数列互质 题目描述 给出一个长度为 n 的数列 { a[1] , a[2] , a[3] , … , a[n] }&#xff0c;以及 m 组询问 ( l[i] , r[i] , k[i])。 求数列下标区间在 [ l[i] , r[i] ] 中有多少数在该区间中的出现次数与 k[i] 互质&#xff08;最大公约数为1&#xff09;。 输入描述: 第一…

P3211-[HNOI2011]XOR和路径【高斯消元】

正题 题目链接:https://www.luogu.com.cn/problem/P3211 题目大意 一个nnn个点mmm条边的无向图&#xff0c;从111到nnn随机游走。求期望路径异或和。 2≤n≤100,1≤m≤1042\leq n\leq 100,1\leq m\leq 10^42≤n≤100,1≤m≤104 解题思路 因为是异或的期望&#xff0c;很难直…

【随机】Ghd(CF364D)

正题 luogu CF364D 题目大意 给你一个大小为n的集合&#xff0c;选择一个至少为一半的子集&#xff0c;另其gcd最大 解题思路 由于数字个数很多&#xff0c;考虑随机 随机选10个数&#xff0c;对于每个数&#xff0c;先处理出约数&#xff0c;然后求出所有数和当前数的gcd&…

ASP.NET Core2读写InfluxDB时序数据库

在我们很多应用中会遇到有一种基于一系列时间的数据需要处理&#xff0c;通过时间的顺序可以将这些数据点连成线&#xff0c;再通过数据统计后可以做成多纬度的报表&#xff0c;也可通过机器学习来实现数据的预测告警。而时序数据库就是用于存放管理这种有着时间顺序数据的&…

Nature 新研究发布,GPT 驱动的机器人化学家能够自行设计和进行实验,这对科研意味着什么?

文章目录 前言揭秘Coscientist不到四分钟&#xff0c;设计并改进了程序能力越大&#xff0c;责任越大 前言 有消息称&#xff0c;AI 大模型 “化学家” 登 Nature 能够自制阿司匹林、对乙酰氨基酚、布洛芬&#xff0c;甚至连复杂的钯催化交叉偶联反应&#xff0c;也能完成。 …

珂朵莉的约数

来源&#xff1a;牛客网&#xff1a; 题目描述 珂朵莉给你一个长为n的序列&#xff0c;有m次查询 每次查询给两个数l,r 设s为区间[l,r]内所有数的乘积 求s的约数个数mod 1000000007 输入描述: 第一行两个正整数n,m 第二行一个长为n的序列 之后m行每行两个数l和r 输出描述…

AtCoder Regular Contest 110 E.Shorten ABC——坑

计数渣渣不会啊 下学期学概率论与数理统计不知道会不会提升数数能力 E.Shorten ABC 当B数组确定后&#xff0c;不难发现就是所问问题即从B序列选出A序列的方案数。 等效于那么从mn中选出sn个小球&#xff0c;我们假设多选的n个小球是一个隔板&#xff0c;隔出数组A&#xff0…

【DP】Rotating Substrings(CF1363F)

正题 luogu CF1363F 题目大意 给你一个字符串&#xff0c;你以旋转其中一个字串&#xff08;将最后一给点移到前面&#xff0c;然后整体向后移一位&#xff09;&#xff0c;问最少要多少布可以到目标字符串 解题思路 设 fi,jf_{i,j}fi,j​ 为 sss 中的前 iii 个字符构成 ttt…

P3348-[ZJOI2016]大森林【LCT】

正题 题目链接:https://www.luogu.com.cn/problem/P3348 题目大意 有nnn棵树开始只有一个编号为111的节点且为标记点。mmm次操作要求支持 在l∼rl\sim rl∼r的树中的标记点下面加入一个新的编号的节点将l∼rl\sim rl∼r的树上的标记点改为xxx&#xff08;如果没有节点xxx就不…

SmartCode 常见问题

SmartCode 能干什么&#xff1f;SmartCode IDataSource -> IBuildTask -> IOutput > Build EverythingSmartCode的执行流是 数据源->构建任务->输出&#xff0c;也就是说应用场景非常广泛。从DB读取数据结构&#xff0c;最终生成整个解决方案代码生成器&#x…

[数论]线性筛——约数个数与约数和

参考博客 参考博客 参考博客 这个讲的挺好 预备知识点&#xff1a; 大于1的数n可以分解质因数&#xff1a; np1a1p2a2p3a3*…*pka n的约数的个数是(a11) * (a21) * (a31)…(ak1) 我们先用线性筛来筛出素数 bool mark[maxn]; int prim[maxn]; int cnt; void initial() {cnt0;f…

F. Paper Grading(Trie树+dfs序+二维数点)

F. Paper Grading 大佬题解 一般关于前缀的问题基本都是Trie树。 首先将所给字符串建立一棵Trie树&#xff0c;Trie能够解决一个字符串在一个字符串集合中出现的次数&#xff0c;而查询前缀次数只需要找到Trie树中所给字符末尾的位置&#xff0c;那么其子树中打标记的次数即前…

AT2164-[AGC006C]Rabbit Exercise【差分,倍增,数学期望】

正题 题目链接:https://www.luogu.com.cn/problem/AT2164 题目大意 nnn只兔子编号为1∼n1\sim n1∼n&#xff0c;第iii只在坐标轴xix_ixi​处。然后mmm次跳跃&#xff0c;每次给出aia_iai​&#xff0c;编号为aia_iai​的兔子会等概率的选取ai−1a_{i-1}ai−1​和ai1a_{i1}ai1…

k-substrings(CF961F)

正题 luogu CF961F 题目大意 给你一个字符串T&#xff0c;对于k1~n/2&#xff0c;找到最长的串s&#xff0c;满足s是T左右各删除k个字符构成的字串t的前缀后缀&#xff08;不能是整个字符串&#xff09; 解题思路 不难发现&#xff0c;k的答案左右各删一个字符必定能得到k1的…

全面支持开源,微软加速 Visual Studio 和 Azure DevOps 云升级

在 2018 微软技术暨生态大会&#xff08;Microsoft Tech Summit&#xff09;上&#xff0c;微软宣布围绕 Visual Studio 和 Visual Studio Code 开发平台提供一系列新功能与服务&#xff0c;并对 Azure DevOps 研发云进行整合升级&#xff0c;通过 Visual Studio 开发平台与微软…

求约数个数的和

今天一下午都在研究约数的各种性质。。。 求约数个数的和可以用线性筛的方式&#xff0c;线性求解的方式&#xff0c;这应该是最快的 [数论]线性筛——约数个数与约数和 除此之外还有代码更简便方法&#xff1a; 对应的例题 方法一&#xff1a; #include <iostream> …

I. Space Station(hash记忆化+dp)

《文章》陆游 文章本天成&#xff0c;妙手偶得之。 粹然无疵瑕&#xff0c;岂复须人为。 君看古彝器&#xff0c;巧拙两无施。 汉最近先秦&#xff0c;固已殊淳漓。 胡部何为者&#xff0c;豪竹杂哀丝。 后夔不复作&#xff0c;千载谁与期&#xff1f; I. Space Station 大佬…

HttpClient参观记:.net core 2.2 对HttpClient到底做了什么?

.net core 于 10月17日发布了 ASP.NET Core 2.2.0 -preview3&#xff0c;在这个版本中&#xff0c;我看到了一个很让我惊喜的新特性&#xff1a;HTTP Client Performance Improvements &#xff0c;而且在Linux上性能提升了60% !之前就一直苦于 HttpClient 的糟糕特性&#xff…

【线段树】Serious Business(CF1648D)

正题 luogu CF1648D 题目大意 有一个 3*n 的矩阵&#xff0c;1,3行没有行走限制&#xff0c;对于第2行&#xff0c;有m个区间&#xff0c;覆盖第 i 个区间有 kik_iki​ 的代价&#xff0c;只有覆盖的位置才能走&#xff0c;让你从 (1,1) 走到 (3,n)&#xff08;只能向下和向右…

P6378-[PA2010]Riddle【2-SAT】

正题 题目链接:https://www.luogu.com.cn/problem/P6378 题目大意 给出nnn个点mmm条边的一张无向图&#xff0c;图中有kkk种颜色的点。 要求每种颜色选择一个点作为关键点&#xff0c;满足每条边两边至少有一个关键点 求是否有满足的方案 1≤n,m,k≤1061\leq n,m,k\leq 10^…