题面

B 君并不喜欢 OSU,但是 B 君觉得 OSU 这个题不错。

输入 $n$ 和 $m$,一共有 $n$ 次点击,每次可以可能成功或失败。

对于一段长度为 $x$ 连续极长的成功点击序列,得分是 $x^m$。

已知第 $i$ 次点击的成功率是 $\frac{p_i}{100}$。

问期望得分是多少?

因为得分可能很大,并且不是整数,只需要输出得分模 1000000007 的结果即可。

解法

对算法正确性的说明

#include <bits/stdc++.h>
using namespace std;
int n, m, mod = 1000000007;
long long p[100020];
long long a[1020];
long long b[1020];
long long s[1020][120];
long long f[1020];
int main() {
	scanf("%d%d", &n, &m);
	s[0][0] = 1;
	for (int i = 0; i <= m; i++) {
		for (int j = 1; j <= i; j++) {
			s[i][j] = (s[i - 1][j - 1] + j * s[i - 1][j]) % mod;
		}
	}
	for (int i = f[0] = 1; i <= m; i++) {
		f[i] = f[i - 1] * i % mod;
	}
	for (int i = 1; i <= n; i++) {
		scanf("%lld", &p[i]);
		p[i] = p[i] * 570000004 % mod;
		for (int j = m; j > 0; j--) {
			a[j] += a[j - 1];
			a[j] *= p[i];
			a[j] %= mod;
			b[j] += a[j];
			b[j] %= mod;
		}
		a[0] = p[i];
		b[0] += a[0];
		b[0] %= mod;
	}
	long long z = 0;
	for (int i = 1; i <= m; i++) {
		z = (z + b[i - 1] * f[i] % mod * s[m][i]) % mod;
	}
	printf("%lld\n", z);
	return 0;
}