【CF660E】Different Subsets For All Tuples 結論題

【CF660E】Different Subsets For All Tuples

題意:對於全部長度爲n,每一個數爲1,2...m的序列,求出每一個序列的本質不一樣的子序列的數目之和。(多個原序列能夠有相同的子序列)ios

$n,m\le 10^6$spa

題解:結論:一個子序列出現的次數只與其長度有關。blog

咱們能夠分別求出每種長度的子序列出現的總次數,顯然答案爲:string

$\sum\limits_{i=1}^nm^i\sum\limits_{j=i}^nC_{j-1}^{i-1}(m-1)^{j-i}m^{n-j}$it

(上面沒有考慮k=0,一會要單獨計算)io

繼續化簡class

$\sum\limits_{j=1}^nm^{n-j}\sum\limits_{i=1}^jC_{j-1}^{i-1}(m-1)^{j-i}m^i$stream

$\sum\limits_{j=1}^nm^{n-j+1}(2m-1)^{j-1}$im

就完事了。di

#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;
}
相關文章
相關標籤/搜索