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;
}
相关推荐
JieE21215 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21215 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术20 小时前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦21 小时前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
通信小呆呆2 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人