CF388D. Fox and Perfect Sets

题意:求最大元素\(le n\)的线性空间的个数


给神题跪了 orz


容易想到 每个线性基对应唯一的线性空间,我们可以统计满足条件的对应空间不同的线性基个数

每一位我们插入一个向量,就获得了这一位的控制权,否则这一位是自由的

因为要\(le n\),可以使用数位DP

从高位到低位考虑,设当前第i位,已经插入了j个向量

没有天际线的限制

  • 插入向量i的话,之前的向量位i必须是0,1种情况
  • 不插入向量i的话,之前的向量位i可以任选,\(2^j\)种情况

考虑天际线的限制

  • 不插入向量i,有\(2^{j-1}\)种情况可以继续顶着天际线
  • 如果a[i]==1,还有\(2^{j-1}\)种情况可以小于天际线
  • a[i]==1时可以插入向量i

然后我的转移方程写的好丑啊....然后鏼鏼鏼了一个简短的写法

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
typedef long long ll;
#define pii pair<int, int>
#define fir first
#define sec second
const int N=40, P=1e9+7;
inline ll read() {
char c=getchar(); ll x=0, f=1;
while(c<'0' || c>'9') {if(c=='-')f=-1; c=getchar();}
while(c>='0' && c<='9') {x=x*10+c-'0'; c=getchar();}
return x*f;
} int n, f[N][N][2], a[N], len;
ll mi[N];
inline void mod(int &x) {if(x>=P) x-=P;}
int dfs(int d, int j, int sky) { //printf("dfs %d %d %d\n",d,j,sky);
if(d==0) return 1;
if(f[d][j][sky] != -1) return f[d][j][sky];
int &now = f[d][j][sky], lim = sky ? a[d] : 1;
now=0;
if(!sky) {
mod(now += mi[j] * dfs(d-1, j, 0) %P );
mod(now += dfs(d-1, j+1, 0)%P );
} else {
mod(now += (j==0 ? 1 : mi[j-1]) * dfs(d-1, j, sky && 0==lim) %P);
if(a[d]==1) mod(now += dfs(d-1, j+1, sky && 1==lim)%P ),
mod(now += (j==0 ? 0 : mi[j-1]) * dfs(d-1, j, sky && 1==lim) %P );
}
//for(int i=0; i<=lim; i++) {
// mod(now += (j==0 ? !i : mi[j-1]) * dfs(d-1, j, sky && i==lim) %P);
// if(i==1) mod(now += dfs(d-1, j+1, sky && i==lim));
//} return now;
}
int main() {
freopen("in","r",stdin);
mi[0]=1;
for(int i=1; i<=30; i++) mi[i] = (mi[i-1]<<1)%P;
n=read();
while(n) a[++len]=n&1, n>>=1;
memset(f, -1, sizeof(f));
printf("%d", dfs(len, 0, 1));
}

BZOJ CF388D. Fox and Perfect Sets [线性基 数位DP]的更多相关文章

  1. 【做题】CF388D. Fox and Perfect Sets——线性基&数位dp

    原文链接https://www.cnblogs.com/cly-none/p/9711279.html 题意:求有多少个非空集合\(S \subset N\)满足,\(\forall a,b \in ...

  2. codeforces 388D Fox and Perfect Sets(线性基+数位dp)

    #include<bits/stdc++.h> using namespace std; #define fi first #define se second #define mp mak ...

  3. 数位DP CF388D - Fox and Perfect Sets

    题目地址 一个整数perfect集合满足性质:集合中随意两个整数的异或和仍在这个集合中. 求最大数不超过K的perfect集合的个数. 每一个集合都是一个线性的向量空间. .能够通过全然的高斯消元得出 ...

  4. Codeforces 388 D. Fox and Perfect Sets

    $ >Codeforces \space 388 D.  Fox and Perfect Sets<$ 题目大意 : 定义一个完美的集合 \(S\) ,当且仅当 \(S\) 非负非空,且 ...

  5. BZOJ.4184.shallot(线段树分治 线性基)

    BZOJ 裸的线段树分治+线性基,就是跑的巨慢_(:з」∠)_ . 不知道他们都写的什么=-= //41652kb 11920ms #include <map> #include < ...

  6. BZOJ 3105 [CQOI2013]新Nim游戏 ——线性基

    [题目分析] 神奇的题目,两人都可以第一次取走足够多堆的石子. nim游戏的规则是,如果异或和为0,那么就先手必输,否则先手有必胜策略. 所以只需要剩下一群异或和为0就可以了. 先排序,线性基扫一遍即 ...

  7. bzoj 4184 shallot——线段树分治+线性基

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4184 本来想了可持久化trie,不过空间是 nlogn (出一个节点的时候把 tot 复原就 ...

  8. BZOJ.3105.[CQOI2013]新Nim游戏(线性基 贪心 博弈论)

    题目链接 如果后手想要胜利,那么在后手第一次取完石子后 可以使石子数异或和为0.那所有数异或和为0的线性基长啥样呢,不知道.. 往前想,后手可以取走某些石子使得剩下石子异或和为0,那不就是存在异或和为 ...

  9. BZOJ 2460: [BeiJing2011]元素 贪心,线性基

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=2460 解法:从大到小排序,依次贪心的添加到当前集合就可以了,需要动态维护线性基.用拟阵证明 ...

随机推荐

  1. A. Vasya and Football

    A. Vasya and Football time limit per test 2 seconds memory limit per test 256 megabytes input standa ...

  2. 浏览器的统一指针事件:Pointer Event

    在早期的浏览器,输入的事件其实相对单纯,只有考虑到鼠标和键盘两种:而当时的鼠标事件,其实就是 click.mousedown.mouseup 等等的事件.但是当手机.平板开始流行时候,再移动装置上的主 ...

  3. ImportError: No module named 'BaseHTTPServer':解决方案

    利用python写了一小段代码,里面使用到了Python标准库的BaseHTTPServer来构建一个基础HTTP服务器: 1 #-*- coding:utf-8 -*- 2 import http. ...

  4. IOS safari浏览器登陆时Cookie无法保存的问题

    近期完成了一个儿童的测评项目,测试到最后的时候发现在ipad mini上登陆成功之后无法跳转页面,而安卓和pc端都可以,找了大半天bug,发现其他的苹果设备都没问题,只能一个一个的调试,结果发现设备的 ...

  5. [国嵌攻略][179][OpenSSL加密系统]

    未加密传输的安全弊端 如果在网络传输中没有加密,就是以明文传输.传输的数据可以被抓包软件直接截获,并能读取里面的数据. 加密基本原理 1.对称加密 2.非对称加密 2.1.公钥私钥 公钥和私密要配对. ...

  6. html日历(3)

    <!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...

  7. redis学习笔记(14)---redis基本命令总结

    http://doc.redisfans.com/ 网页,对所有redis命令的用法与示例进行了详细的描述 概述 Redis的键值可以使用物种数据类型:字符串,散列表,列表,集合,有序集合.本文详细介 ...

  8. Eclipse配置maven环境

    一.什么是maven? Maven是一个项目管理工具,它包含了一个项目对象模型 (Project Object Model),一组标准集合,一个项目生命周期(Project Lifecycle),一个 ...

  9. ip 淘宝ip库 精简版

    <?php header('Content-type: text/html; charset=utf-8'); //根据ip获取城市.网络运营商等信息 function findCityByIp ...

  10. 【开发技术】JAutodoc使用指南

    JAutodoc使用指南 下载地址:http://sourceforge.net/projects/jautodoc/?source=directory 使用方法:http://wenku.baidu ...