数学课(math)

题目描述

wzy又来上数学课了…… 虽然他很菜,但是数学还是懂一丢丢的。老师出了一道题,给定一个包含nn个元素的集合P=1,2,3,…,nP=1,2,3,…,n,求有多少个集合A⊆PA⊆P,满足任意x∈Ax∈A有2x∉A2x∉A,且对于AA在PP中的补集BB,也满足任意x∈Bx∈B有2x∉B2x∉B。

wzy花费了1E100天终于算出来了这个答案,但是可恶的caoxia居然又加了一个条件!他要求AA的大小恰好为mm,这样又有多少个AA呢?

这回wzy真的不会了,他找到了你,希望能够得到帮助。由于答案太大,你只需要输出答案mod10000019mod10000019即可。

输入

第一行两个数,为n,qn,q。接下来qq行每行一个数mm,询问大小为mm的AA一共有多少个。

输出

共qq行,每行一个数,表示方案数mod10000019

样例解释

对于第一个样例,P={1,2,3},P可以选{1},{2},{1,3},{2,3},大小为1的两种,大小为2的也有两种。

对于第二个样例,我想到了一个绝妙的解释,可惜这里写不下。

数据范围及约定

subtask1:20pts,n,m,q≤20n,m,q≤20.

subtask2:30pts,n,m,q≤5,000n,m,q≤5,000.

subtask3:30pts,n,m≤10,000,000,q≤100,000n,m≤10,000,000,q≤100,000

subtask4:20pts,n,m≤1018,q≤100,000n,m≤1018,q≤100,000

来源

noip2018模拟-南外


solution

暴力想法,把每个奇数和他乘上2的若干倍丢进数组

可知我的集合一定要选一半

令x=num/2;

那么如果个数为奇数,可以选x/x+1

为偶数则只能选x个

假设奇数个数的数目为NA,偶数个数为NB,sum为一定得选的个数

答案即C(NA,m-sum)*2^NB

也就是选出m-sum个x+1 nb的可以瞎选(每个两种方案)

注意到模数只有10000019,C(n,m)可以用lucas定理求

lucas忘光。。。

如果n<m可以直接return 0,因为这样子N!一定包括mod

#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define ll long long
#define mod 10000019
using namespace std;
int q;
ll n,m,x,h[mod+10],ny[mod+10],num[70];
ll work(ll a,ll num){
ll ans=1;
while(num){
if(num&1)ans=ans*a;
a=a*a;a%=mod;ans%=mod;num>>=1;
}
return ans;
}
ll C(int N,int M){
if(N<M)return 0;
return h[N]*ny[M]%mod*ny[N-M]%mod;
}
ll Lucas(ll N,ll M){
if(!M)return 1;
return Lucas(N/mod,M/mod)*C(N%mod,M%mod)%mod;
}
int main()
{
cin>>n>>q;
ll x=2,la=n,cnt=0,sum=0,na=0,nb=0;
if(la%2==0)la--;
while(1){ ll now=n/x;
if(now%2==0)now++;
else now+=2;
num[++cnt]=(la-now)/2+1;
if(cnt&1)na=na+num[cnt];
else nb=nb+num[cnt];
sum=sum+num[cnt]*(cnt/2);
if(now==1)break;la=now-2;x<<=1;
}
h[0]=1;for(int i=1;i<mod;i++)h[i]=h[i-1]*i%mod;
ny[mod-1]=work(h[mod-1],mod-2);
for(int i=mod-2;i;i--)ny[i]=ny[i+1]*(i+1)%mod;ny[0]=1;
while(q--){
scanf("%lld",&m);
if(m<sum||m>na+sum){puts("0");continue;}
ll ans=Lucas(na,m-sum)*work(2,nb)%mod;
ans=(ans+mod)%mod;
printf("%lld\n",ans);
}
return 0;
}

数学课(math)的更多相关文章

  1. math ceil以及math floor,math:round

    ◎Math.ceil()执行向上舍入,即它总是将数值向上舍入为最接近的整数:◎Math.floor()执行向下舍入,即它总是将数值向下舍入为最接近的整数:◎Math.round()执行标准舍入,即它总 ...

  2. Math.ceil()、Math.floor()和Math.round()

    下面来介绍将小数值舍入为整数的几个方法:Math.ceil().Math.floor()和Math.round(). 这三个方法分别遵循下列舍入规则: Math.ceil()执行向上舍入,即它总是将数 ...

  3. How to give a math lecture

    摘自 http://www.timhsu.net/courses/generic/proof.pdf   或 http://www.timhsu.net/courses/generic/how-to- ...

  4. Java中Math类的几个四舍五入方法的区别

    JAVA取整以及四舍五入 下面来介绍将小数值舍入为整数的几个方法:Math.ceil().Math.floor()和Math.round(). 这三个方法分别遵循下列舍入规则:Math.ceil()执 ...

  5. JavaScript中Math对象的方法介绍

    1.比较最值方法 比较最值有两种方法,max() 和 min() 方法. 1.1 max() 方法,比较一组数值中的最大值,返回最大值. var maxnum = Math.max(12,6,43,5 ...

  6. JavaScript Math和Number对象

    目录 1. Math 对象:数学对象,提供对数据的数学计算.如:获取绝对值.向上取整等.无构造函数,无法被初始化,只提供静态属性和方法. 2. Number 对象 :Js中提供数字的对象.包含整数.浮 ...

  7. Chrome V8引擎系列随笔 (1):Math.Random()函数概览

    先让大家来看一幅图,这幅图是V8引擎4.7版本和4.9版本Math.Random()函数的值的分布图,我可以这么理解 .从下图中,也许你会认为这是个二维码?其实这幅图告诉我们一个道理,第二张图的点的分 ...

  8. Math.random()

    Math.random() 日期时间函数(需要用变量调用):var b = new Date(); //获取当前时间b.getTime() //获取时间戳b.getFullYear() //获取年份b ...

  9. Math.abs()方法 取绝对值

    定义和用法 abs() 方法可返回数的绝对值. 语法 Math.abs(x) 参数 描述 x 必需.必须是一个数值. 返回值 x 的绝对值. 实例 在本例中,我将取得正数和负数的绝对值: <sc ...

随机推荐

  1. STM32启动流程

    启动文件主要工作: . 设置堆栈指针SP=_initial_sp . 设置PC指针=Reset_Handler . 配置系统时钟 . 配置外部SRAM用于程序变量等数据存储(可选) . 调用C库中的_ ...

  2. MyISAM 和 InnoDB 的区别与优化

    MyISAM 和 InnoDB 的基本区别 1.InnoDB不支持FULLTEXT类型的索引. 2.InnoDB 中不保存表的具体行数,也就是说,执行select count(*) from tabl ...

  3. [牛客OI测试赛2]F假的数学游戏(斯特灵公式)

    题意 输入一个整数X,求一个整数N,使得N!恰好大于$X^X$. Sol 考试的时候只会$O(n)$求$N!$的前缀和啊. 不过最后的结论挺好玩的 $n! \approx \sqrt{2 \pi n} ...

  4. cf550C. Divisibility by Eight(结论)

    题意 给出长度为$n$的字符串,判断是否能删除一些数后被$8$整除 Sol 神仙题啊Orz 结论: 若数字的后三位能被$8$整除,则该数字能被$8$整除 证明 设$x = 10000 * a_i + ...

  5. ABAP读取长文本的方法

    SAP中所有的项目文本都存在以下两张数据表中: 1. STXH  抬头项目文本 透明表 2. STXL  明细项目文本   透明表 长文本读取方法 首先在STXH和STXL中根据OBJECT NAME ...

  6. 6- vue django restful framework 打造生鲜超市 -完成商品列表页(下)

    Vue+Django REST framework实战 搭建一个前后端分离的生鲜超市网站 Django rtf 完成 商品列表页下 drf中的request和response drf对于django的 ...

  7. php下关于Cannot use a scalar value as an array的解决办法

    今天在测试php程序的时候,出现了一个错误提示:Cannot use a scalar value as an array,这个错误提示前几天也出过,当时好像稍微调了一下就好了,也没深究,今天却又出现 ...

  8. linux命令学习-2

    1. 对于已经在前台执行的命令,可以重新放到后台执行,首先按ctrl+z暂停已经运行的进程,然后使用jobs查看进程编号n:2. bg命令将停止的作业放到后台运行 bg %n3. kill -9 XX ...

  9. Linux命令之---find

    命令简介 find明林用于查找目录下的文件,同时也可以调用其他命令执行相应的操作 命令格式 find pathname -options [-print -exec -ok ...] find [选项 ...

  10. 步骤详解安装Apache web服务器

    1.在上右键è安装 安装后apache web服务器自动启动. 在右下角出现. Apache安装之后有一个默认的网站目录 在浏览器上通过网站就可以访问到该目录下的文件. 2.测试 在浏览器输上请求lo ...