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;
}
相关推荐
Dfreedom.8 小时前
计算机视觉全景图
人工智能·算法·计算机视觉·图像算法
Morwit9 小时前
【力扣hot100】 1. 两数之和
数据结构·c++·算法·leetcode·职场和发展
无小道9 小时前
算法——暴力+优化
算法·优化·暴力
Free Tester9 小时前
如何判断 LeakCanary 报告的严重程度
java·jvm·算法
zyq99101_110 小时前
DFS算法实战:经典例题代码解析
python·算法·蓝桥杯·深度优先
智者知已应修善业10 小时前
【51单片机单按键切换广告屏】2023-5-17
c++·经验分享·笔记·算法·51单片机
广州灵眸科技有限公司10 小时前
为RK3588注入澎湃算力:RK1820 AI加速卡完整适配与评测指南
linux·网络·人工智能·物联网·算法
qinian_ztc10 小时前
frida 14.2.18 安装报错解决
算法·leetcode·职场和发展
AI应用实战 | RE10 小时前
012、检索器(Retrievers)核心:从向量库中智能查找信息
人工智能·算法·机器学习·langchain
凤年徐10 小时前
C++手撕红黑树:从0到200行,拿下STL map底层核心
c++·后端·算法