AtCoder Beginner Contest 450 G题题解

AtCoder Beginner Contest 450 - AtCoderhttps://atcoder.jp/contests/abc450

题意:

给你一个长度为n的集合,每次从中随机选出两个数x,y,删除他们,并将x-y加入集合

求集合最后一个元素x的平方的期望值

题解

1.转化

易得最后一个数可以表示为

使用表示的期望值,则

,则

对于所有,都是相同的

不妨设,则

,则

然后就是大型推公式环节了

2.推导

表示的下一步,表示的下一步,

由于数一共有个,所以

因为是定值,所以

因为最初的定义为

所以我们可以得出

接下来只要求出就可以递推计算答案了

因为,所以只需要满足就必定成立

因此,不妨取,得到

即可计算出答案的值

代码:

cpp 复制代码
#include<bits/stdc++.h>
#define int long long
using namespace std;
const int mod=998244353;
int n,c[210000],a[210000],b[210000];
int qpow(int x,int y)
{
	x%=mod;
	if(y==0) return 1;
	int xx=qpow(x*x%mod,y>>1);
	if(y&1) return xx*x%mod;
	return xx;
}
signed main() 
{
	scanf("%lld",&n);
	for(int i=1;i<=n;i++) scanf("%lld",&c[i]);
	a[1]=1,b[1]=0;
	int S=0,Q=0;
	for(int i=1;i<=n;i++)
	{
		S=(S+c[i])%mod;
		Q=(Q+c[i]*c[i])%mod;
	}
	if(n==1)
	{
		printf("%lld",Q);
		return 0;
	}
	for(int i=2;i<=n;i++)
	{
		int jty=(i-1)*i%mod;
		a[i]=(((i-1)*(i-4)%mod*a[i-1]%mod-2*b[i-1])%mod+mod)%mod*qpow(jty,mod-2)%mod;
		b[i]=(4*(i-1)%mod*a[i-1]%mod+(i*(i-1)+2)%mod*b[i-1]%mod)%mod*qpow(jty,mod-2)%mod;
	}
	int ans=(a[n]*S%mod*S%mod+b[n]*Q%mod)%mod;
	printf("%lld",ans);
	return 0;
}
相关推荐
ccLianLian1 小时前
数论·快速幂和逆元
数据结构·算法
没头脑的男大1 小时前
华为题目152乘积最大子数组
算法·华为
Yeats_Liao2 小时前
华为开源自研AI框架昇思MindSpore应用案例:WaveNet实现音乐生成
人工智能·深度学习·算法·机器学习·边缘计算
_饭团2 小时前
C 语言数据存储全解析:原反补码、大小端与 IEEE 754 浮点数
c语言·数据结构·算法·leetcode·面试·蓝桥杯·学习方法
2401_873204652 小时前
C++与Docker集成开发
开发语言·c++·算法
j_xxx404_2 小时前
力扣--分治(归并排序)算法题II:计算右侧小于当前元素的个数,翻转对(无痛通关困难题)
开发语言·数据结构·c++·算法·leetcode
setmoon2142 小时前
多协议网络库设计
开发语言·c++·算法
Sylvia-girl2 小时前
删除有序数组中的重复项
数据结构·算法
2501_908329852 小时前
嵌入式LinuxC++开发
开发语言·c++·算法