DTOJ 3987: 数学课
题目描述
wzy又来上数学课了…… 虽然他很菜,但是数学还是懂一丢丢的。老师出了一道题,给定一个包含$n$个元素的集合$P=1,2,3……n$求有多少集合$A \subseteq P$,满足$x \in A$且$2x \notin A$且对于$A$在$P$中的补集也要满足相同条件。给定$m$求大小为$m$的$A$有多少个,输出答案$mod~10000019$。
输入
第一行$n,q$,接下来$q$行,每行一个$m$。
输出
对于每个$m$输出答案$mod~10000019$
【样例输入】
3 3
0
1
2
【样例输出】
0
2
2
【数据范围】
$n,m<=10^{18}~q<=100000$
分析:
又是计数类问题,应该有DP写法。$n,m$很大,但模数比较小,又可以考虑卢卡斯。
恩,思路比较多。可以先考虑观察找找性质。
$x$和$2x$不能再同一个集合,我们将将$x$和$2x$连一条边,那么$n$个数,就被划分成了若干条链,然后对于每一条链,发现只有两种选法(间隔一个选一个),而且每条链都必须选其中一种。那么总共有多少种选法就很显然了。
考虑题目中要求的集合大小为$m$。不难发现存在无解(即答案为0)。我们假设一条链的链长为$2p$或$2p+1$,那么由于每条链都必须选其中的一半,偶数链选出的个数一定为$p$,但奇数链可以选出$p$或$p+1$。所以可以计算出最少要取几个(下界)和最多可以取几个(上界),显然,不在这范围内的$m$就无解了。那么考虑有解情况,偶数链都选$p$不会改变选出数的个数,只有奇数链可以取$p$或$p+1$可以影响选出数的个数。我们用$m$减去下界,然后剩下的数就需要用奇数链中$p+1$多出来的$1$补齐,那么就考虑是那几条奇数链补上的一即可。
#include<iostream>
#include<algorithm>
#include<cstdio>
#include<cstring>
#define ll long long
#define p 10000019
using namespace std;
int q,logn;
ll n,m,f[p+5],inv[p+5],l,r,las,mi[70],odd,eve;
inline ll power(ll a,ll x){
ll res=1;
for(;x;a=a*a%p,x>>=1) if(x&1) res=res*a%p;
return res;
}
inline ll C(ll a,ll b){
return a<b?0:f[a]*inv[f[b]]%p*inv[f[a-b]]%p;
}
inline ll lucas(ll a,ll b){
if(a<p&&b<p) return C(a,b);
return C(a%p,b%p)*lucas(a/p,b/p)%p;
}
int main(){
scanf("%lld%d",&n,&q);
inv[1]=f[0]=1;
for(int i=1;i<p;i++) f[i]=f[i-1]*i%p;
for(int i=2;i<p;i++) inv[i]=inv[p%i]*(p-p/i)%p;
for(ll i=n;i;i>>=1) logn++;
mi[0]=1;for(int i=1;i<=logn;i++) mi[i]=mi[i-1]*2;
for(int j=logn;j;j--){
ll now=n/mi[j-1];
ll num=(now+1)/2-las;
las=(now+1)/2;
l+=j/2*num;r+=(j+1)/2*num;
j&1?odd+=num:eve+=num;
}
for(int i=1;i<=q;i++){
scanf("%lld",&m);
if(m<l||m>r){puts("0");continue;}
else printf("%lld\n",lucas(odd,m-l)*power(2,eve)%p);
}
return 0;
}
总结:
计数类问题真的很多都是排列组合和DP。这道题也有DP推导的方法。
DTOJ 3987: 数学课的更多相关文章
- hdu 3987 Harry Potter and the Forbidden Forest 求割边最少的最小割
view code//hdu 3987 #include <iostream> #include <cstdio> #include <algorithm> #in ...
- ZOJ 3987 Numbers(Java枚举)
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3987 题意:给出一个数n,现在要将它分为m个数,这m个数相加起来必须等于n ...
- 洛谷P2826 LJJ的数学课
题目背景 题目描述(本题是提高组第二题难度+) 题目描述 \(LJJ\)又要开始上数学课啦!(\(T1\),永恒不变的数学) \(LJJ\)的\(Teacher\)对上次的考试很不满意(其实是出题人对 ...
- HDU 3987 Harry Potter and the Forbidden Forest(边权放大法+最小割)
Harry Potter and the Forbidden Forest Time Limit: 5000/3000 MS (Java/Others) Memory Limit: 65536/ ...
- 数学课(math)
数学课(math) 题目描述 wzy又来上数学课了-- 虽然他很菜,但是数学还是懂一丢丢的.老师出了一道题,给定一个包含nn个元素的集合P=1,2,3,-,nP=1,2,3,-,n,求有多少个集合A⊆ ...
- 【hdu 3987】Harry Potter and the Forbidden Forest
[Link]:http://acm.hdu.edu.cn/showproblem.php?pid=3987 [Description] 给出一张有n个点的图,有的边又向,有的边无向,现在要你破坏一些路 ...
- 【DTOJ】2704:数字互换
DTOJ 2704:数字互换 解题报告 2017.11.11 第一版 ——由翱翔的逗比w原创 题目信息: 题目描述 输入两个数作为交换数,输出已交换顺序后的两个值. 输入 两个整数,空格隔开 输出 ...
- 【DTOJ】2703:两个数的余数和商
DTOJ 2703:两个数的余数和商 解题报告 2017.11.10 第一版 ——由翱翔的逗比w原创,引用<C++ Primer Plus(第6版)中文版> 题目信息: 题目描述 给你a ...
- 【DTOJ】1001:长方形周长和面积
DTOJ 1001:长方形周长和面积 解题报告 2017.11.05 第一版 ——由翱翔的逗比w原创 题目信息: 题目描述 已知长方形的长和宽,求长方形的周长和面积? 输入 一行:空格隔开的两个整 ...
随机推荐
- [火星补锅] 水题大战Vol.2 T1 && luogu P1904 天际线 题解 (线段树)
前言: 当时考场上并没有想出来...后来也是看了题解才明白 解析: 大家(除了我)都知道,奇点和偶点会成对出现,而出现的前提就是建筑的高度突然发生变化.(这个性质挺重要的,我之前没看出来) 所以就可以 ...
- PCB板HDI板几阶是什么意思
http://blog.sina.com.cn/s/blog_55ff6d5d0102xxvx.html
- Luogu P2081 [NOI2012]迷失游乐园 | 期望 DP 基环树
题目链接 基环树套路题.(然而各种错误调了好久233) 当$m=n-1$时,原图是一棵树. 先以任意点为根做$dp$,求出从每一个点出发,然后只往自己子树里走时路径的期望长度. 接着再把整棵树再扫一遍 ...
- Bzoj通过5题纪念
我A了五题啦!!!
- 51nod_1003 阶乘后面0的数量(求N!中5的个数,数论)
题意: n的阶乘后面有多少个0? 6的阶乘 = 1*2*3*4*5*6 = 720,720后面有1个0. Input 一个数N(1 <= N <= 10^9) OutPut 输出0的数 ...
- hdu 5094 Maze (BFS+状压)
题意: n*m的迷宫.多多要从(1,1)到达(n,m).每移动一步消耗1秒.有P种钥匙. 有K个门或墙.给出K个信息:x1,y1,x2,y2,gi 含义是(x1,y1)与(x2,y2)之间有gi ...
- Jmeter 踩坑记录(七)
1.master连不上Slave机 解决方法:telnet 192.168.xx.xx 1099 看IP 端口通不通,如果通 OK,不通,检查关闭防火墙或者开放端口 2.salve 连不上 mast ...
- 性能工具之代码级性能测试工具ContiPerf
前言 做性能的同学一定遇到过这样的场景:应用级别的性能测试发现一个操作的响应时间很长,然后要花费很多时间去逐级排查,最后却发现罪魁祸首是代码中某个实现低效的底层算法.这种自上而下的逐级排查定位的方法, ...
- 攻防世界 WEB 高手进阶区 PHP2 Writeup
攻防世界 WEB 高手进阶区 PHP2 Writeup 题目介绍 题目考点 url 二次解码 index.phps 文件(第一次使用dirsearch可能扫不到,需要加到工具字典里) php 简单语法 ...
- $router 和 $route的区别
router router是VueRouter的一个对象,通过Vue.use(VueRouter)和VueRouter构造函数得到一个router的实例对象,这个对象中是一个全局对象,他包含了所有的路 ...