【CF660E】Different Subsets For All Tuples(组合数学)
大致题意: 有一个长度为\(n\)的数列,每个位置上数字的值在\([1,m]\)范围内,则共有\(m^n\)种可能的数列。分别求出每个数列中本质不同的子序列个数,然后求和。
一些分析
首先,我们单独考虑空序列的个数\(m^n\),然后接下来就可以只考虑非空序列的个数了。
假设有一个长度为\(i\)的子序列(\(1\le i\le n\)),且其在序列中的位置分别为\(pos_1,pos_2,...,pos_i\),值分别为\(val_1,val_2,...,val_i\)。
则我们强制在\(1\sim pos_1-1\)范围内不能出现\(val_1\),\(pos_1+1\sim pos_2-1\)范围内不能出现\(val_2\),以此类推。
所以,在前\(pos_i\)个位置中,除\(pos_{1\sim i}\)这\(i\)个位置填\(val_{i\sim i}\)外,如上所述,其余\(pos_i-i\)个位置各有\(m-1\)种填法。
而在第\(pos_i\)个位置之后就可以随便填了,每个位置都有\(m\)种填法。
推式子
通过之前的分析,于是得到式子如下:
\]
对于这个式子的解释:
首先,用\(i\)枚举子序列长度,而长度为\(i\)的子序列共有\(m^i\)种可能。
接下来\(j\)枚举\(pos_i\),而\(pos_{1\sim i-1}\)依次选择\([1,pos_i-1]\)(即这里的\([1,j-1]\))这个范围内的任意位置都是合法的,就相当于在\(j-1\)个位置中选择\(i-1\)个位置,方案数就是\(C_{j-1}^{i-1}\)。
从前文可得,\(pos_i-i\)(即这里的\(j-i\))个位置有\(m-1\)种填法,\(n-pos_i\)(即这里的\(n-j\))个位置有\(m\)种填法。
于是便得到上述式子。
然后就是化简:
先移项,把\(m^i\)移进去得到:
\]
改变枚举顺序,得到:
\]
观察到组合数中的\(i-1\)和\(j-1\),不难想到直接将枚举的\(i,j\)减\(1\),即:
\]
然后我们可以化简一下系数,发现这些\(1\)和\(-1\)恰好抵消了,得到:
\]
然后我们拎出\(m^{n-j}\),就可以得到:
\]
那这样有什么好处呢?
回想一下二项式定理:\((x+y)^n=\sum_{i=0}^{n-1}x^iy^{n-i}\)。
这似乎与上面式子的后半部分有几分相似。
于是就可以化简得到:
\]
这个式子可以\(O(nlogn)\)快速幂计算,也可以直接\(O(n)\)计算。
总而言之,可以过了。
代码
#include<bits/stdc++.h>
#define Tp template<typename Ty>
#define Ts template<typename Ty,typename... Ar>
#define Reg register
#define RI Reg int
#define Con const
#define CI Con int&
#define I inline
#define W while
#define N 1000000
#define X 1000000007
#define Qinv(x) Qpow(x,X-2)
#define Inc(x,y) ((x+=(y))>=X&&(x-=X))
using namespace std;
int n,m;
I int Qpow(RI x,RI y) {RI t=1;W(y) y&1&&(t=1LL*t*x%X),x=1LL*x*x%X,y>>=1;return t;}//快速幂
int main()
{
RI i,ans,p1,p2,b1,b2;
scanf("%d%d",&n,&m),ans=p1=Qpow(m,n),p2=1,b1=Qinv(m),b2=(1LL*2*m-1)%X;//初始化
for(i=0;i^n;++i) Inc(ans,1LL*p1*p2%X),p1=1LL*p1*b1%X,p2=1LL*p2*b2%X;//O(n)计算答案
return printf("%d",ans),0;//输出答案
}
【CF660E】Different Subsets For All Tuples(组合数学)的更多相关文章
- 【组合数学】cf660E. Different Subsets For All Tuples
比较套路的组合数学题 For a sequence a of n integers between 1 and m, inclusive, denote f(a) as the number of d ...
- cf660E Different Subsets For All Tuples
For a sequence a of n integers between 1 and m, inclusive, denote f(a) as the number of distinct sub ...
- 【CF660E】Different Subsets For All Tuples 结论题
[CF660E]Different Subsets For All Tuples 题意:对于所有长度为n,每个数为1,2...m的序列,求出每个序列的本质不同的子序列的数目之和.(多个原序列可以有相同 ...
- Educational Codeforces Round 11 E. Different Subsets For All Tuples 动态规划
E. Different Subsets For All Tuples 题目连接: http://www.codeforces.com/contest/660/problem/E Descriptio ...
- Codeforces 660E Different Subsets For All Tuples【组合数学】
看了官方题解+q神的讲解才懂... 智商问题.. 讲道理..数学真的比脱单难啊... 题目链接: http://codeforces.com/problemset/problem/660/E 题意: ...
- Different Subsets For All Tuples CodeForces - 660E (组合计数)
大意: 定义$f(a)$表示序列$a$本质不同子序列个数. 给定$n,m$, 求所有长$n$元素范围$[1,m]$的序列的$f$值之和. 显然长度相同的子序列贡献是相同的. 不考虑空串, 假设长$x$ ...
- FFT/NTT复习笔记&多项式&生成函数学习笔记Ⅱ
因为垃圾电脑太卡了就重开了一个... 前传:多项式Ⅰ u1s1 我预感还会有Ⅲ 多项式基础操作: 例题: 26. CF438E The Child and Binary Tree 感觉这题作为第一题还 ...
- 2019.03.14 ZJOI2019模拟赛 解题报告
得分: \(100+100+0=200\)(\(T1\)在最后\(2\)分钟写了出来,\(T2\)在最后\(10\)分钟写了出来,反而\(T3\)写了\(4\)个小时爆\(0\)) \(T1\):风王 ...
- Codeforces 895.C Square Subsets
C. Square Subsets time limit per test 4 seconds memory limit per test 256 megabytes input standard i ...
随机推荐
- Car Flash ECU Programmer From autonumen
Whether you’re a home car owner or an auto mechanic — you can save thousands of dollars on car maint ...
- Linux数组基础
执行结果:
- stream2
import java.util.ArrayList; import java.util.List; import java.util.Set; import java.util.function.B ...
- Zookeeper的集群配置和Java测试程序 (一)
概述 Zookeeper是Apache下的项目之一,倾向于对大型应用的协同维护管理工作.IBM则给出了IBM对ZooKeeper的认知: Zookeeper 分布式服务框架是 Apache Hadoo ...
- Unity Screen Screen.currentResolution 当前分辨率
The current screen resolution (Read Only). 当前屏幕的分辨率.(只读) If the player is running in window mode, th ...
- 性能测试工具LoadRunner08-LR之Virtual User Generator 检查点
步骤: 1.点击Vuser--->Run-Time Settings 2.点击Preferences--->Enable Image and text check 3.点击Content ...
- (转)sdd for aix 安装及基本命令
总结出自多个文件(自己做的项目和网上找的资料) 原文:http://blog.csdn.net/yujin2010good/article/details/11395701 一.sddpcm安装 要安 ...
- python文件操作和集合(三)
对文件的操作分三步: 1.打开文件获取文件的句柄,句柄就理解为这个文件 2.通过文件句柄操作文件 3.关闭文件. 文件基本操作: f = open('file.txt','r') #以 ...
- shell 重定向 1> 2> &>
0表示标准输入1表示标准输出2表示标准错误输出> 默认为标准输出重定向,与 1> 相同2>&1 意思是把 标准错误输出 重定向到 标准输出.&>file 意思是 ...
- 记一次无法登录 wine QQ
入Linux坑第X天,过了五一小长假,回来布置我的环境,本来不应该装一些不必要的东西分自己心,但还是装上,以便不时之需. 把输入法装好后,就安装了QQ,查过资料,都说wine_QQ国际版可以使用,于是 ...