Codeforces 388D Fox and Perfect Sets
链接:CF388D
题目大意
给定一个数\(n\),求选择\(0 \sim n\)中任意个数的数字组成的集合\(S\)中,有多少满足若\(a\in S,b\in S\),则\(a \bigoplus b \in S\),输出方案数对\(1e9+7\)取模。
题目分析
设\(f[i][j][k]\)表示从第\(i\)位到最高位,已经选了\(j\)个基,且由基\(\bigoplus\)得到的最大值与\(n\)的差值是否在\(2^i\)以内的方案数。
况一:当\(k=0\)(异或最大值\(+2^i<n\))时,考虑第\(i-1\)位。
如果该位要作为单独一个基,那么有\(f[i-1][j+1][0]+=f[i][j][0]\),
该位单独作基,则新增情况数为之前有的情况,视为在之前每种情况上\(x\)新增一个\(2^{i-1} \)的基,
由设可保证新构成的集合异或最大值与\(n\)的差值在\(2^{i-1}\)之外,所以算在\(f[i-1][j+1][0]\)中。
如果该位不单独作基,而是放入已经拥有的j个基中,
那么对于每个基,都有放与不放两种选择,共\(2^j\)种,\(f[i-1][j][0]+=2^j*f[i][j][0]\)。
况二:当\(k=1\)(异或最大值\(+2^i>=n\))时,考虑第\(i-1\)位。
讨论\(n\)在第\(i-1\)位是否为\(1\):
1、\(n\)在第\(i-1\)位不为\(1\),异或最大值\(+2^{i-1}>n\):
此时最大值无法新增一个\(2^{i-1}\)。
那么,我们只能继承令第\(i-1\)位为偶数个\(1\)的情况,因为只有这样,最大值才不会改变,共\(2^{j-1}\)种。
2、\(n\)在第\(i-1\)位为\(1\),异或最大值\(+2^{i-1}≤n\):
如果在第\(i-1\)位取\(0\),那么新得到的集合异或最大值\(+2^{i-1}≤n\),因此应存入\(f[i-1][j][0]\)中,共\(2^{j-1}\)种。
如果在第\(i-1\)位取\(1\),那么新得到的集合异或最大值\(+2^{i-1}≥n\),因此应存入\(f[i-1][?][1]\)中。
对于第\(i-1\)位单独作基的情况,可以有\(f[i][j][1]\)种,存入\(f[i-1][j+1][1]\)中,\(f[i-1][j+1][1]+=f[i][j][1]\)。
对于第\(i-1\)位不单独作基的情况,可以对每个基选择放与不放,且必须放奇数个,共\(2^{j-1}\)种选择,
因此\(f[i-1][j][1]+=2^{j-1}*f[i][j][1]\)。
注意:
对于所有情况,当\(j=0\),对于选择第\(i-1\)位为\(0\)的情况,\(2^{j-1}\)算作\(1\);
对于选择第\(i-1\)位为\(1\)的情况,\(2^{j-1}\)算作\(0\),因为就算你没有选择一个基,你的异或和仍可以视作\(0\)。
代码实现
#include<iostream>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<cstdio>
#include<iomanip>
#include<cstdlib>
#define MAXN 0x7fffffff
typedef long long LL;
const int mod=1e9+7;
using namespace std;
inline int Getint(){
register int x=0,f=1;
register char ch=getchar();
while(!isdigit(ch)){
if(ch=='-')f=-1;
ch=getchar();
}
while(isdigit(ch)){
x=x*10+ch-'0';
ch=getchar();
}
return x*f;
}
int ans,f[35][35][2];
void Add(int &x,int y){x=((x+y>=mod)?(x+y-mod):(x+y));}
int main(){
int n=Getint();
f[30][0][1]=1;
for(int i=30;i>0;i--)
for(int j=0;j<=30;j++){
Add(f[i-1][j][0],(1LL<<j)*f[i][j][0]%mod);
Add(f[i-1][j+1][0],f[i][j][0]);
int x=j?(1<<(j-1)):1,y=j?(1<<(j-1)):0;
if(n>>(i-1)&1){
Add(f[i-1][j][0],(LL)x*f[i][j][1]%mod);
Add(f[i-1][j][1],(LL)y*f[i][j][1]%mod);
Add(f[i-1][j+1][1],f[i][j][1]);
}else Add(f[i-1][j][1],(LL)x*f[i][j][1]%mod);
}
for(int i=0;i<=30;i++)
Add(ans,f[0][i][0]),Add(ans,f[0][i][1]);
cout<<ans;
return 0;
}
Codeforces 388D Fox and Perfect Sets的更多相关文章
- codeforces 388D Fox and Perfect Sets(线性基+数位dp)
#include<bits/stdc++.h> using namespace std; #define fi first #define se second #define mp mak ...
- Codeforces 388 D. Fox and Perfect Sets
$ >Codeforces \space 388 D. Fox and Perfect Sets<$ 题目大意 : 定义一个完美的集合 \(S\) ,当且仅当 \(S\) 非负非空,且 ...
- BZOJ CF388D. Fox and Perfect Sets [线性基 数位DP]
CF388D. Fox and Perfect Sets 题意:求最大元素\(le n\)的线性空间的个数 给神题跪了 orz 容易想到 每个线性基对应唯一的线性空间,我们可以统计满足条件的对应空间不 ...
- 数位DP CF388D - Fox and Perfect Sets
题目地址 一个整数perfect集合满足性质:集合中随意两个整数的异或和仍在这个集合中. 求最大数不超过K的perfect集合的个数. 每一个集合都是一个线性的向量空间. .能够通过全然的高斯消元得出 ...
- 【做题】CF388D. Fox and Perfect Sets——线性基&数位dp
原文链接https://www.cnblogs.com/cly-none/p/9711279.html 题意:求有多少个非空集合\(S \subset N\)满足,\(\forall a,b \in ...
- CodeForces 388A Fox and Box Accumulation (模拟)
A. Fox and Box Accumulation time limit per test:1 second memory limit per test:256 megabytes Fox Cie ...
- Codeforces 388C Fox and Card Game (贪心博弈)
Codeforces Round #228 (Div. 1) 题目链接:C. Fox and Card Game Fox Ciel is playing a card game with her fr ...
- codeforces 510B. Fox And Two Dots 解题报告
题目链接:http://codeforces.com/problemset/problem/510/B 题目意思:给出 n 行 m 列只有大写字母组成的字符串.问具有相同字母的能否组成一个环. 很容易 ...
- codeforces 477B B. Dreamoon and Sets(构造)
题目链接: B. Dreamoon and Sets time limit per test 1 second memory limit per test 256 megabytes input st ...
随机推荐
- Java-javaFx库运用-时钟显示
JavaFx是开发Java GUI程序的新框架.JavaFX应用可以无缝地在桌面或web浏览器中运行.具有内建的2D.3D动画支持,以及视频和音频的回放功能,可以作为一个应用独立运行或者在浏览器中运行 ...
- Java-Class-C:org.springframework.http.MediaType
ylbtech-Java-Class-C:org.springframework.http.MediaType 1.返回顶部 1.1. /* * Copyright 2002-2018 the ori ...
- webstorm快捷键、支持vue文件等部分使用技巧
转载:https://www.cnblogs.com/seven077/p/9771474.html 1.常用快捷键 shift+↑ 向上选取代码块shift+↓ 向下选取代码块ctrl+/ 注释/取 ...
- 前端开发者进阶之ECMAScript新特性--Object.create
前端开发者进阶之ECMAScript新特性[一]--Object.create Object.create(prototype, descriptors) :创建一个具有指定原型且可选择性地包含指 ...
- Spring源码分析(一):从哪里开始看spring源码(系列文章基于Spring5.0)
概述 对于大多数第一次看spring源码的人来说,都会感觉不知从哪开始看起,因为spring项目源码由多个子项目组成,如spring-beans,spring-context,spring-core, ...
- 接口测试 java+httpclient+testng+excel
最近项目不忙,研究了下java实现接口自动化,借助testng+excel实现数据驱动 目前只用post方式测试,返回结果列没有通过列名去找 另外,请求参数是转义之后的,接口之间的依赖也是个问题,批量 ...
- 校园商铺-4店铺注册功能模块-10店铺注册之js实现
1. 建立js目录和文件 1.1 建立js目录 在webapp下新建文件夹js,再在js目录下新建shop文件夹. 1.2 js文件 js的功能: 1.从后台获取到店铺分类.区域等是信息,将它填充到前 ...
- List、Map、Set 三个接口,存取元素时,各有什么特点
List与Set都是单列元素的集合,它们有一个功共同的父接口Collection. Set里面不允许有重复的元素, 存元素:add方法有一个boolean的返回值,当集合中没有某个元素,此时add方法 ...
- SpringBoot2.0+ 使用Log4j2日志输出
据说Log4j2相比log4j效率有很大提升. pom.xml导入 <dependency> <groupId>org.springframework.boot</gro ...
- 2428: [HAOI2006]均分数据
模拟退火.一种十分玄学的随机算法,网上可以查到比较详细的资料. 先随机地把数分成m组,每次随机地选择一个数,一开始直接选最小的一组,后来就随机一组,把这个数换到该组看看答案能不能变小,如果变小则换,如 ...