博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CF1208F Bits And Pieces
阅读量:4701 次
发布时间:2019-06-09

本文共 824 字,大约阅读时间需要 2 分钟。

我们设\(f[i]\)表示有多少个数的二进制下的子集值为\(i\)

显然当\(f[i]>=2\)时,\(i\)是可以通过\(a_j\&a_k\)得到的

然后我们枚举\(a_i\),从高位到低位考虑,尽量多取\(a_i\)二进制下没有的位。

然后取最大值就行了,至于满足\(i<j<k\)从大到小枚举就行了

注意:

二进制分解的时候不要枚举子集,时间复杂度太高了。考虑我们只需要\(f[i]=2\)就行了,并且当\(f[i]=2\)时,我们就可以退出了

代码:

#include
#include
#include
#include
using namespace std;#define rg registervoid read(int &x){ char ch;bool ok; for(ok=0,ch=getchar();!isdigit(ch);ch=getchar())if(ch=='-')ok=1; for(x=0;isdigit(ch);x=x*10+ch-'0',ch=getchar());if(ok)x=-x;}const int maxn=1e6+10;int n,m,a[maxn],cnt[1<<22],ans;void add(int x,int y){ if(cnt[x]>=2)return ; if(y==-1)return cnt[x]++,void(); add(x,y-1);if(x&(1<
<
=0;i--){ if(!(x&(1<
<
=2)ans|=(1<

转载于:https://www.cnblogs.com/lcxer/p/11505803.html

你可能感兴趣的文章
【34.14%】【BZOJ 3110】 [Zjoi2013]K大数查询
查看>>
【 henuacm2016级暑期训练-动态规划专题 A 】Cards
查看>>
第五篇:白话tornado源码之褪去模板的外衣
查看>>
设备常用框架framework
查看>>
bootstrap模态框和select2合用时input无法获取焦点(转)
查看>>
MockObject
查看>>
BZOJ4516: [Sdoi2016]生成魔咒(后缀自动机)
查看>>
查看手机已经记住的WIFI密码
查看>>
最新版IntelliJ IDEA2019 破解教程(2019.08.07-情人节更新)
查看>>
C# 两个datatable中的数据快速比较返回交集或差集
查看>>
关于oracle样例数据库emp、dept、salgrade的mysql脚本复杂查询分析
查看>>
adb shell am 的用法
查看>>
iOS10 UI教程视图和子视图的可见性
查看>>
FindChildControl与FindComponent
查看>>
中国城市json
查看>>
android下载手动下载Android SDK
查看>>
C++学习:任意合法状态下汉诺塔的移动(原创)
查看>>
leetcode133 - Clone Graph - medium
查看>>
一点小基础
查看>>
UNET学习笔记2 - 高级API(HLAPI)
查看>>