标签:不同 item class printf pac bbb define lan href
http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1202
第1行:一个数N,表示序列的长度(1 <= N <= 100000) 第2 - N + 1行:序列中的元素(1 <= a[i] <= 100000)
输出a的不同子序列的数量Mod 10^9 + 7。
4 1
一眼望去令f[i]表示以a[i]结尾的子序列个数,f[i]=SUM{f[j] | a[j]!=a[i] } 累加求和就是答案。
可以维护一个计算过的fi的总和,减去之前出现过这个数的fi就是当前的f的值。
1 #include<bits/stdc++.h> 2 using namespace std; 3 #define LL long long 4 LL mod=1e9+7; 5 LL f[100005]; 6 LL tmp[100005]; 7 int a[100005]; 8 int main() 9 { 10 int N,i,j,k; 11 cin>>N; 12 for(i=1;i<=N;++i) 13 { 14 scanf("%d",a+i); 15 } 16 f[0]=1; 17 LL s=1,ans=0; 18 for(i=1;i<=N;++i) 19 { 20 f[i]=(mod-tmp[a[i]]+s)%mod; 21 tmp[a[i]]=(tmp[a[i]]+f[i])%mod; 22 s=(s+f[i])%mod; 23 ans=(ans+f[i])%mod; 24 } 25 printf("%lld\n",ans); 26 return 0; 27 }
标签:不同 item class printf pac bbb define lan href
原文地址:http://www.cnblogs.com/zzqc/p/7467286.html