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;
}
相关推荐
AI科技星4 分钟前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅6 分钟前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表
王老师青少年编程20 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【贪心与二分判定】:数列分段 Section II
c++·算法·贪心·csp·信奥赛·二分判定·数列分段 section ii
V搜xhliang024642 分钟前
OpenClaw科研全场景用法:从文献到实验室的完整自动化方案
运维·开发语言·人工智能·python·算法·microsoft·自动化
汉克老师1 小时前
GESP2025年3月认证C++五级( 第三部分编程题(2、原根判断))
c++·算法·模运算·gesp5级·gesp五级·原根·分解质因数
数据皮皮侠1 小时前
上市公司创新韧性数据(2000-2024)|顶刊同款 EIR 指数
大数据·人工智能·算法·智慧城市·制造
WL_Aurora1 小时前
Python 算法基础篇之链表
python·算法·链表
科研前沿1 小时前
纯视觉无感解算 + 动态数字孪生:室内外无感定位技术全新升级
大数据·人工智能·算法·重构·空间计算
Wadli2 小时前
26.单调栈
算法
晨曦夜月2 小时前
进程的五大状态及特殊进程解析
linux·服务器·算法