当前位置: 首页 > news >正文

怎么去除自己做的网站手机地图app下载安装

怎么去除自己做的网站,手机地图app下载安装,如何用wordpress做网站,wordpress本地测试手机Description 一个有N个元素的集合有2^N个不同子集(包含空集),现在要在这2^N个集合中取出若干集合(至少一个),使得它们的交集的元素个数为K,求取法的方案数,答案模1000000007。&#…

Description

一个有N个元素的集合有2^N个不同子集(包含空集),现在要在这2^N个集合中取出若干集合(至少一个),使得它们的交集的元素个数为K,求取法的方案数,答案模1000000007。(是质数喔~)

Input

一行两个整数N,K

Output

一行为答案。

Sample Input

3 2

Sample Output

6

HINT

【样例说明】

假设原集合为{A,B,C}

则满足条件的方案为:{AB,ABC},{AC,ABC},{BC,ABC},{AB},{AC},{BC}

【数据说明】

对于100%的数据,1≤N≤1000000;0≤K≤N;

Solution

首先考虑一下容斥
设$f(k)$表示选出一些集合使它们交集大小至少为$k$的方案数。
那么$f(k)=C_n^k \times (2^{2^{n-k}}-1)$
这玩意儿怎么理解呢?也就是先把那$i$个数确定下来,然后有$2^{n-k}$个集合可以包含那$k$个数。这些集合要么选要么不选,但不能一个都不选,也就是不能为空集。所以有$2^{2^{n-k}}-1$种选择方法。
那么容斥系数呢?可以发现当计算交集至少为$k$的方案时候,交集至少为$j$的方案($j>k$)会被计算$C_j^k$次。
也就是说,
$f(k)$的系数为$1$。
$f(k+1)$的系数为$-C_{k+1}^k$。
$f(k+2)$的系数为$-C_{k+2}^k+C_{k+1}^k\times C_{k+2}^{k+1}=C_{k+2}^k$
为什么$f(k+2)$能那么推呢……因为$C_N^M\times C_M^S=C_N^S\times C_{N-S}^{N-M}$
搞到现在基本可以组合计数搞搞出解了,至于那个大的一比的$2^{2^{n-k}}$,根据欧拉定理直接指数取模$φ(MOD)$就好了,显然$φ(MOD)=MOD-1$。

Code

 1 #include<iostream>
 2 #include<cstdio>
 3 #define N (1000009)
 4 #define LL long long
 5 #define MOD (1000000007)
 6 using namespace std;
 7 
 8 LL n,k,ans,inv[N],fac[N],facinv[N],p[N];
 9 
10 void Init()
11 {
12     inv[1]=fac[0]=facinv[0]=p[0]=1;
13     for (int i=1; i<=n; ++i)
14     {
15         if (i!=1) inv[i]=(MOD-MOD/i)*inv[MOD%i]%MOD;
16         fac[i]=fac[i-1]*i%MOD; facinv[i]=facinv[i-1]*inv[i]%MOD;
17         p[i]=p[i-1]*2%(MOD-1);
18     }
19 }
20 
21 LL Qpow(LL a,LL b)
22 {
23     LL ans=1;
24     while (b)
25     {
26         if (b&1) ans=ans*a%MOD;
27         a=a*a%MOD; b>>=1;
28     }
29     return ans;
30 }
31 
32 LL C(LL n,LL m)
33 {
34     if (n<m) return 0;
35     return fac[n]*facinv[m]%MOD*facinv[n-m]%MOD;
36 }
37 
38 int main()
39 {
40     scanf("%lld%lld",&n,&k);
41     Init();
42     for (int i=k,j=1; i<=n; ++i,j=-j)
43         ans+=j*C(n,i)*(Qpow(2,p[n-i])-1)%MOD*C(i,k)%MOD;
44     ans=(ans%MOD+MOD)%MOD;
45     printf("%lld\n",ans);
46 }

转载于:https://www.cnblogs.com/refun/p/10145811.html

http://www.lbrq.cn/news/2577925.html

相关文章:

  • 在网站做的pdf有水印如何删除阿里巴巴官网首页
  • 美国社交网站 做仿牌域名交易平台
  • 买服饰网站建设商城网站建设
  • 北京网站建设方案百度seo文章
  • 职业装定制百度seo排名优化
  • 网站建设渠道百度指数1000搜索量有多少
  • 1688黄页网芒果品种大全搜狗关键词优化软件
  • 北京网站制作设计公司排名开发一款app软件需要多少钱
  • 百度seo排名帝搜软件优化百度搜索
  • 吉林市市政建设集团网站男生最喜欢的浏览器推荐
  • 电信宽带做网站服务器新浪微指数
  • 做详情页生成代码的网站全国人大常委会
  • 泊头哪给做网站的好网络营销的四大基础理论
  • html前端网站开发PPTb站免费建网站
  • 公司网站建设公一键优化表格
  • 可以做家教的网站有哪些网络推广营销方法
  • 帮小公司代账一个月费用优化网站教程
  • 如何后台修改网站联系人购物网站页面设计
  • 做动画上传网站赚钱么企业网站seo服务
  • 网站用什么服务器seo销售好做吗
  • 谷歌广告优化师凌哥seo
  • 鞍山信息港征婚谷歌seo怎么做
  • 建站系统做网站搜索排名影响因素
  • 网站seo 优帮云参考消息网国内新闻
  • 武汉 网站开发市场推广和销售的区别
  • wordpress编程主题搜索引擎优化排名案例
  • 建筑设计专业的网站指数函数
  • 怎么在网站后台做图片新闻网页制作与设计
  • 电影片头在线制作网站免费关键词搜索工具
  • 个人信息网站模板凡科建站登录
  • [硬件电路-138]:模拟电路 - 什么是正电源?什么是负电源?集成运放为什么有VCC+和VCC-
  • 2106. 摘水果
  • Flutter各大主流状态管理框架技术选型分析及具体使用步骤
  • LangGraph认知篇-Persistence 持久化
  • 【stm32】按键控制LED以及光敏传感器控制蜂鸣器
  • 构造类型--结构体,共同体联合体,枚举