题目分析:

题解好高深......

我给一个辣鸡做法算了,题解真的看不懂。

注意到方差恒为$0$,那么其实就是要我们求$\sum_{i=0}^{n}\binom{n}{i}(i^k-(n-i)^k)^2$。

转换一下

$\sum_{i=0}^{n}\binom{n}{i}(i^k-(n-i)^k)^2$

$=2\sum_{i=0}^{n}\binom{n}{i}(i^{2k}-i^k(n-i)^k)$

注意到$i^{2k}$与$i^k(n-i)^k$在模$m$意义下都是一个周期为$m$的数列,那么我们需要求出每隔$m$个的组合数的和,即:

$2\sum_{i=0}^{m-1}(\sum_{j=0}^{\frac{n-i}{m}}\binom{n}{i+j*m}(i^{2k}-i^k(n-i)^k))$

把焦点放到内部的求和里面去,它是很简单的一个式子,试着转化它。首先我们可以根据Lucas定理分析出,对于外部的$i$,它的结果中一定有$ \binom{n\%m}{i} $。

剩下的是什么?首先有不等式$i+j*m \leq n\%m + \left \lfloor \frac{n}{m} \right \rfloor*m$。在这里我们毫无疑问地认为$i \leq n\%m$。否则对结果无影响。

我们接受$\left \lfloor \frac{n}{m} \right \rfloor$的所有影响,取满它,取满一排,它是$2$的次幂。

所以这个式子就等于$2\sum_{i=0}^{m-1}(\binom{n\%m}{i}*2^{\left \lfloor \frac{n}{m} \right \rfloor}(i^{2k}-i^k(n-i)^k))$

$\left \lfloor \frac{n}{m} \right \rfloor$很大,采用费马定理优化。

这样我们就可以解决它在$O(mlogk)$的时间内了。

注意,如果我们会线性求逆元以及线性筛,可以去掉log。

代码:

 #include<bits/stdc++.h>
using namespace std; const int maxn = ; int mod,nr,k,np;
char str[maxn];
int str2[maxn]; int c[maxn],rw[maxn]; void read(){
scanf("%s",str);
scanf("%d%d",&k,&mod);
int len = strlen(str);
for(register int i=;i<len;i++){ nr = nr*+str[i]-''; nr %= mod; }
for(register int i=,num=;i<len;i++){
np = np*+str[i]-''; str2[i] = np/mod; np %= mod;
} np = ;
for(register int i=;i<len;i++){
np = np*+str2[i]; np %= (mod-);
}
} int fast_pow(int now,int pw){
int ans = ,dd = now,base = ;
while(base <= pw){
if(base & pw){ans = (1ll*ans*dd)%mod;}
dd = (1ll*dd*dd)%mod;
base<<=;
}
return ans;
} int prime[maxn/],flag[maxn],num;
void get_prime(int N){
rw[] = ; flag[] = ;
for(int i=;i<=N;i++){
if(!flag[i]){prime[++num]=i;rw[i]=fast_pow(i,k);}
for(int j=;j<=num&&i*prime[j]<=N;j++){
flag[i*prime[j]] = ;
rw[i*prime[j]] = (1ll*rw[i]*rw[prime[j]])%mod;
if(i%prime[j] == ) break;
}
}
} void init(){
get_prime(nr);
np = fast_pow(,np+); c[] = ;
for(register int i=;i<=nr;i++){
c[i] = (1ll*c[i-]*(nr-i+))%mod;
c[i] = (1ll*c[i]*fast_pow(i,mod-))%mod;
}
} void work(){
int ans = ;
for(register int i=;i<mod;i++){
if(i > nr) break;
int hh = rw[i];
int pp = ((1ll*hh*hh)%mod) - (1ll*hh*rw[nr-i])%mod;
if(pp < ) pp += mod;
pp = (1ll*pp*c[i])%mod;
ans += pp; if(ans >= mod) ans -= mod;
}
ans += mod; if(ans >= mod) ans -=mod;
ans = (1ll*np*ans)%mod;
printf("%d",ans);
} int main(){
read();
init();
work();
return ;
}

51Nod1778 小Q的集合 【组合数】【Lucas定理】的更多相关文章

  1. uoj86 mx的组合数 (lucas定理+数位dp+原根与指标+NTT)

    uoj86 mx的组合数 (lucas定理+数位dp+原根与指标+NTT) uoj 题目描述自己看去吧( 题解时间 首先看到 $ p $ 这么小还是质数,第一时间想到 $ lucas $ 定理. 注意 ...

  2. [Swust OJ 247]--皇帝的新衣(组合数+Lucas定理)

    题目链接:http://acm.swust.edu.cn/problem/0247/ Time limit(ms): 1000 Memory limit(kb): 65535   Descriptio ...

  3. luogu4345 [SHOI2015]超能粒子炮·改(组合数/Lucas定理)

    link 输入\(n,k\),求\(\sum_{i=0}^k{n\choose i}\)对2333取模,10万组询问,n,k<=1e18 注意到一个2333这个数字很小并且还是质数这一良好性质, ...

  4. 【(好题)组合数+Lucas定理+公式递推(lowbit+滚动数组)+打表找规律】2017多校训练七 HDU 6129 Just do it

    http://acm.hdu.edu.cn/showproblem.php?pid=6129 [题意] 对于一个长度为n的序列a,我们可以计算b[i]=a1^a2^......^ai,这样得到序列b ...

  5. 【BZOJ-4591】超能粒子炮·改 数论 + 组合数 + Lucas定理

    4591: [Shoi2015]超能粒子炮·改 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 95  Solved: 33[Submit][Statu ...

  6. 组合数(Lucas定理) + 快速幂 --- HDU 5226 Tom and matrix

    Tom and matrix Problem's Link:   http://acm.hdu.edu.cn/showproblem.php?pid=5226 Mean: 题意很简单,略. analy ...

  7. 【组合数+Lucas定理模板】HDU 3037 Saving

    acm.hdu.edu.cn/showproblem.php?pid=3037 [题意] m个松果,n棵树 求把最多m个松果分配到最多n棵树的方案数 方案数有可能很大,模素数p 1 <= n, ...

  8. CodeForces-451E:Devu and Flowers (母函数+组合数+Lucas定理)

    Devu wants to decorate his garden with flowers. He has purchased n boxes, where the i-th box contain ...

  9. HDU3037Saving Beans(组合数+lucas定理)

    Problem Description Although winter is far away, squirrels have to work day and night to save beans. ...

随机推荐

  1. iptables防火墙规则的添加、删除、修改、保存

    原文地址:https://blog.csdn.net/educast/article/details/52093390 本文介绍iptables这个Linux下最强大的防火墙工具,包括配置iptabl ...

  2. koa服务器搭建基础

    之前我一直使用rails搭建网站.rails与koa的基本理念很相似,都是基于中间件提供一层层的服务.所不同的是,rails有很多内置的中间件,这使得开发者只需要关注MVC模块以及页面路由.而Koa这 ...

  3. 字符串的查找KMP

    基本思想,当出现不匹配的时候,就知晓一部分文本内容(因为在匹配失败前已经发生匹配) P[0 ~ k-1] == P[j-k ~ j-1] //KMP #include<iostream> ...

  4. 机器学习第一篇——最近邻kNN

    机器学习监督学习中,根据解决问题的连续性和离散型,分为分类问题和回归问题.最邻近算法kNN是一种最为直接和简便的分类方法. kNN本质上,是计算目标到模型的欧式距离,从而判定目标所属的类别. 首先,在 ...

  5. Elasticsearch - 简单介绍

    Elasticsearch 简介 1. 什么是 Elasticsearch ElasticSearch 是一个基于 Lucene 的搜索服务器. 它了一个分布式多 用户能力的全文搜索引擎,能够达到实时 ...

  6. iOS上手指点击波纹效果的实现

    https://www.jianshu.com/p/35e6f53ca0fe 2016.10.19 22:00* 字数 135 阅读 2468评论 2喜欢 7 闲暇时间做了一个反馈手指点击屏幕的效果, ...

  7. Django model操作

    一.各种查询统计操作   def all(self) # 获取所有的数据对象 def filter(self, *args, **kwargs) # 条件查询 # 条件可以是:参数,字典,Q def ...

  8. 13 Connectors: show contrast/oppistion

    1 "but" 和 "yet" 用来显示两个意思之间的对比关系.在写作中,当 "but" 和"yet" 将两个分句连为一 ...

  9. zTree树形菜单使用实例

    在每个节点添加 id 和 pid, id 表示当前节点编号,pid 表示父节点编号 第一步:在页面显示菜单位置,添加 ul设置 class=”ztree” 第二步:开启简单数据格式支持 第三步:编写树 ...

  10. java学习之—排序

    package test3; public class Sort{ /** * 冒泡排序 * @param array */ public void bubbleSort(int[] array) { ...