bzoj千题计划247:bzoj4903: [Ctsc2017]吉夫特
预备知识:
C(n,m)是奇数的充要条件是 n&m==m
由卢卡斯定理可以推出
选出的任意相邻两个数a,b 的组合数计算C(a,b)必须是奇数
所以可以设dp[i][j] 表示前i个数里面,选的最后一个数是第j个数的方案数
转移的时候,枚举前i-1个数选的最后一个数k,
若C(k,i)是奇数,dp[i][j]+=dp[i-1][k]
时间复杂度:O(n^3)
#include<cstdio>
#include<iostream> using namespace std; #define N 20 const int mod=1e9+; int a[N]; int dp[N][N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} bool judge(int x,int y)
{
if(!x) return true;
return (x&y)==y;
} int main()
{
int n;
read(n);
for(int i=;i<=n;++i) read(a[i]);
dp[][]=;
for(int i=;i<=n;++i)
for(int j=;j<=i;++j)
{
dp[i][j]=;
for(int k=;k<j;++k)
if(judge(a[k],a[j]))
{
dp[i][j]+=dp[i-][k];
dp[i][j]-=dp[i][j]>=mod ? mod : ;
}
}
int ans=;
for(int i=;i<=n;++i)
{
ans+=dp[n][i]-;
ans-=ans>=mod ? mod : ;
}
printf("%d",ans);
}
优化:
dp[i] 表示选的最后一个数是第i个数的方案数
枚举前面的i-1个数,
若C(a[i],a[j])是奇数,dp[i]+=dp[j]
时间复杂度:O(n^2)
#include<cstdio>
#include<iostream> using namespace std; #define N 2018 const int mod=1e9+; int a[N]; int dp[N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} int main()
{
int n;
read(n);
for(int i=;i<=n;++i) read(a[i]);
for(int i=;i<=n;++i) dp[i]=;
for(int i=;i<=n;++i)
{
for(int j=;j<i;++j)
if((a[j]&a[i])==a[i]) dp[i]+=dp[j];
}
int ans=;
for(int i=;i<=n;++i)
{
ans+=dp[i]-;
ans-=ans>=mod ? mod : ;
}
printf("%d",ans);
}
再优化:
dp[i] 表示选的最后一个数是i的方案数
dp[i] 能转移到i的子集,
所以枚举子集j,若j在i的后面,那么dp[j]+=dp[i]
时间复杂度:O(3^(logn))
#include<cstdio>
#include<iostream> using namespace std; #define N 233334 const int mod=1e9+; int a[N]; int dp[N];
int pos[N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} int main()
{
int n;
read(n);
for(int i=;i<=n;++i) read(a[i]),pos[a[i]]=i;
int bit,sum;
for(int i=;i<=n;++i)
{
dp[a[i]]++;
for(int j=(a[i]-)&a[i];j;j=(j-)&a[i])
if(pos[j]>i)
{
dp[j]+=dp[a[i]];
dp[j]-=dp[j]>=mod ? mod : ;
}
}
int ans=;
for(int i=;i<=n;++i)
{
ans+=dp[a[i]]-;
ans-=ans>=mod ? mod : ;
}
printf("%d",ans);
}
常数优化:
边读入边计算,接着累计进答案
就可以不用判断子集是否在i的后面
因为在前面的话,前面的已经累积进答案了
#include<cstdio>
#include<iostream> using namespace std; #define N 233334 const int mod=1e9+; int a[N]; int dp[N]; void read(int &x)
{
x=; char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) { x=x*+c-''; c=getchar(); }
} int main()
{
int n,x;
int ans=;
read(n);
for(int i=;i<=n;++i)
{
read(x);
dp[x]++;
for(int j=(x-)&x;j;j=(j-)&x)
{
dp[j]+=dp[x];
dp[j]-=dp[j]>=mod ? mod : ;
}
ans+=dp[x]-;
ans-=ans>=mod ? mod : ;
}
printf("%d",ans);
}
bzoj千题计划247:bzoj4903: [Ctsc2017]吉夫特的更多相关文章
- bzoj千题计划300:bzoj4823: [Cqoi2017]老C的方块
http://www.lydsy.com/JudgeOnline/problem.php?id=4823 讨厌的形状就是四联通图 且左右各连一个方块 那么破坏所有满足条件的四联通就好了 按上图方式染色 ...
- bzoj千题计划196:bzoj4826: [Hnoi2017]影魔
http://www.lydsy.com/JudgeOnline/problem.php?id=4826 吐槽一下bzoj这道题的排版是真丑... 我还是粘洛谷的题面吧... 提供p1的攻击力:i,j ...
- bzoj千题计划280:bzoj4592: [Shoi2015]脑洞治疗仪
http://www.lydsy.com/JudgeOnline/problem.php?id=4592 注意操作1 先挖再补,就是补的范围可以包含挖的范围 SHOI2015 的题 略水啊(逃) #i ...
- bzoj千题计划177:bzoj1858: [Scoi2010]序列操作
http://www.lydsy.com/JudgeOnline/problem.php?id=1858 2018 自己写的第1题,一遍过 ^_^ 元旦快乐 #include<cstdio> ...
- bzoj千题计划317:bzoj4650: [Noi2016]优秀的拆分(后缀数组+差分)
https://www.lydsy.com/JudgeOnline/problem.php?id=4650 如果能够预处理出 suf[i] 以i结尾的形式为AA的子串个数 pre[i] 以i开头的形式 ...
- bzoj千题计划304:bzoj3676: [Apio2014]回文串(回文自动机)
https://www.lydsy.com/JudgeOnline/problem.php?id=3676 回文自动机模板题 4年前的APIO如今竟沦为模板,,,╮(╯▽╰)╭,唉 #include& ...
- bzoj千题计划292:bzoj2244: [SDOI2011]拦截导弹
http://www.lydsy.com/JudgeOnline/problem.php?id=2244 每枚导弹成功拦截的概率 = 包含它的最长上升子序列个数/最长上升子序列总个数 pre_len ...
- bzoj千题计划278:bzoj4590: [Shoi2015]自动刷题机
http://www.lydsy.com/JudgeOnline/problem.php?id=4590 二分 这么道水题 没long long WA了两发,没判-1WA了一发,二分写错WA了一发 最 ...
- bzoj千题计划250:bzoj3670: [Noi2014]动物园
http://www.lydsy.com/JudgeOnline/problem.php?id=3670 法一:KMP+st表 抽离nxt数组,构成一棵树 若nxt[i]=j,则i作为j的子节点 那么 ...
随机推荐
- 结对编程--C语言子程序词法分析
一.问题描述 C语言小子集表的定义 2.设计单词属性值,各类表格(表示标识符表.常量表),单词符号及机内表示,采用标准输入和输出的方式.程序从键盘接收代码,遇到代码结束符"#"时结 ...
- nginx反向代理设置自定义错误页面
为nginx反向代理设置自定义错误页面 转:https://blog.csdn.net/u014433030/article/details/77507839 如果我们的nginx配置了反向代理,如下 ...
- Android 测试之Monkey
一.什么是Monkey Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中.它向系统发送伪随机的用户事件流(如按键输入.触摸屏输入.手势输入等),实现对正在开发的应用程序进 ...
- ssm整合各配置文件
ssm整合 1.配置web.xml <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns ...
- yocto-sumo源码解析(二): oe-buildenv-internal
1 首先,脚本先对运行方式进行了检测: if ! $(return >/dev/null 2>&1) ; then echo 'oe-buildenv-internal: erro ...
- 分布式理论:深入浅出Paxos算法
前言 Paxos算法是用来解决分布式系统中,如何就某个值达成一致的算法.它晦涩难懂的程度完全可以跟它的重要程度相匹敌.目前关于paxos算法的介绍已经非常多,但大多数是和稀泥式的人云亦云,却很少有人能 ...
- 微软职位内部推荐-Senior Software Engineer-DUT
微软近期Open的职位: Document Understanding and Task (DUT) team in STCA focuses on semantic understanding an ...
- tomcat运行JSP时产生的错误:”javax.servlet.servletexception: java.lang.nosuchmethoderror”
这个错误其实是多次重复编译JAVA文件导致的,需要clean操作,简单的来说就是删除tomcat下work文件夹中工作空间,也可以理解为自己的虚拟路径,比如我运行的jsp的路径:localhost:8 ...
- Leetcode——30.与所有单词相关联的字串【##】
@author: ZZQ @software: PyCharm @file: leetcode30_findSubstring.py @time: 2018/11/20 19:14 题目要求: 给定一 ...
- 剑指offer:合并两个排序的链表
题目描述: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则. 解题思路: 这道题应该考察也是链表的相关操作.具体实现,新建一个新的链表,用两个指针分别指向两 ...