zoukankan      html  css  js  c++  java
  • 【CF660E】Different Subsets For All Tuples 结论题

    【CF660E】Different Subsets For All Tuples

    题意:对于所有长度为n,每个数为1,2...m的序列,求出每个序列的本质不同的子序列的数目之和。(多个原序列可以有相同的子序列)

    $n,mle 10^6$

    题解:结论:一个子序列出现的次数只与其长度有关。

    我们可以分别求出每种长度的子序列出现的总次数,显然答案为:

    $sumlimits_{i=1}^nm^isumlimits_{j=i}^nC_{j-1}^{i-1}(m-1)^{j-i}m^{n-j}$

    (上面没有考虑k=0,一会要单独计算)

    继续化简

    $sumlimits_{j=1}^nm^{n-j}sumlimits_{i=1}^jC_{j-1}^{i-1}(m-1)^{j-i}m^i$

    $sumlimits_{j=1}^nm^{n-j+1}(2m-1)^{j-1}$

    就完事了。

    #include <cstdio>
    #include <cstring>
    #include <iostream>
    using namespace std;
    typedef long long ll;
    const ll P=1000000007;
    ll f1[1000010],f2[1000010],ans;
    int n,m;
    int main()
    {
    	scanf("%d%d",&n,&m);
    	int i;
    	for(f1[0]=f2[0]=i=1;i<=n;i++)	f1[i]=f1[i-1]*m%P,f2[i]=f2[i-1]*(m+m-1)%P;
    	for(ans=f1[n],i=1;i<=n;i++)	ans=(ans+f1[n-i+1]*f2[i-1])%P;
    	printf("%lld",ans);
    	return 0;
    }
  • 相关阅读:
    XV6文件系统
    XV6锁
    PC硬件以及引导加载器
    XV6第一个进程
    XV6操作系统接口
    XV6环境搭建及注意事项
    XV6文件系统
    XV6上下文切换
    少走弯路的十条忠告
    LIBCMTD.lib与libcpmtd冲突的解决方法。
  • 原文地址:https://www.cnblogs.com/CQzhangyu/p/8594623.html
Copyright © 2011-2022 走看看