[cf1479E]School Clubs
对于当前班级状态$S$,定义一个函数$\varphi(S)$,要求其满足:
令结束状态为$S_{end}$,对于任意$S\ne S_{end}$,若其下一个状态为$S'$,则$E(\varphi(S)-\varphi(S'))=1$
由此,归纳即可得到$S$的期望结束步数为为$\varphi(S)-\varphi(S')$
对于一个状态$S$,注意到其与班级编号无关,因此不妨假设其第$i$个班级有$a_{i}$个人(共$m$个班级),再定义一个函数$g(x)$,令$\varphi(S)=\sum_{i=1}^{m}g(a_{i})$
由于为空的班级不影响状态,因此$g(0)=0$
更进一步的,根据$E(\varphi(S)-\varphi(S'))=1$,可得
$$
\frac{1}{2}\sum_{i=1}^{m}\frac{a_{i}}{n}(\Delta_{g}(a_{i}-1)-g(1))+\frac{1}{2}\sum_{i=1}^{m}\sum_{j=1}^{m}\frac{a_{i}a_{j}}{n^{2}}(\Delta_{g}(a_{i}-1)-\Delta_{g}(a_{j}-[i=j]))=1
$$
(其中$\Delta_{g}(x)=g(x+1)-g(x)$)
后者在$i=j$时为0,在$i\ne j$时将两个枚举拆开,即
$$
\frac{1}{2}\sum_{i=1}^{m}\frac{a_{i}}{n}(\Delta_{g}(a_{i}-1)-g(1))+\frac{1}{2}\sum_{i=1}^{n}\frac{a_{i}(n-a_{i})}{n^{2}}(\Delta_{g}(a_{i}-1)-\Delta_{g}(a_{i}))=1
$$
将其整理后,即
$$
\sum_{i=1}^{m}\frac{a_{i}}{2n}[(2-\frac{a_{i}}{n})\Delta_{g}(a_{i}-1)-(1-\frac{a_{i}}{n})\Delta_{g}(a_{i})-g(1)]=1
$$
当对于每一个$a_{i}$,中括号内的值恰为$2$时,根据$\sum_{i=1}^{m}a_{i}=n$,即成立
令$g(1)=-2$,再化简后即可得到$\Delta_{g}(x)$
$$
\Delta_{g}(x)=\frac{2n-x}{n-x}\Delta_{g}(x-1)=\prod_{i=1}^{x}\frac{2n-i}{n-i}\Delta_{g}(0)
$$
根据$g(0)=0$以及$g(1)=-2$,可得初始状态$\Delta_{g}(0)=-2$
由此,可得$g(x)=g(0)+\sum_{i=0}^{x-1}\Delta_{g}(i)=-2\sum_{i=0}^{x-1}\prod_{j=1}^{i}\frac{2n-j}{n-j}$,问题即求$\sum_{i=1}^{m}g(a_{i})-g(n)$
之后暴力$o(n)$计算即可,为了避免每一次求逆,需要用分数的形式计算,以及使用”GNU G++17 9.2.0(64 bit,msys 2)“的编译器即可通过
标算做到了$o(\sqrt{n}\log n+m\sqrt{n})$的复杂度,可以看cf上的题解

1 #include<bits/stdc++.h>
2 using namespace std;
3 #define M 1005
4 #define mod 998244353
5 #define ll long long
6 int n,m,x,ans,a[M];
7 ll qpow(int n,int m){
8 ll s=n,ans=1;
9 while (m){
10 if (m&1)ans=ans*s%mod;
11 s=s*s%mod;
12 m>>=1;
13 }
14 return ans;
15 }
16 ll g(int x){
17 ll s1=1,s2=1,ans1=0,ans2=1;
18 for(int i=1;i<=x;i++){
19 ans1=(s1*ans2+s2*ans1)%mod;
20 ans2=s2*ans2%mod;
21 s1=s1*(2*n-i)%mod;
22 s2=s2*(n-i)%mod;
23 }
24 return (mod-2)*ans1%mod*qpow(ans2,mod-2)%mod;
25 }
26 int main(){
27 scanf("%d",&m);
28 for(int i=1;i<=m;i++){
29 scanf("%d",&a[i]);
30 n+=a[i];
31 }
32 for(int i=1;i<=m;i++)ans=(ans+g(a[i]))%mod;
33 printf("%d",(ans+mod-g(n))%mod);
34 }
[cf1479E]School Clubs的更多相关文章
- “北航Clubs”功能规格说明书
1.项目目标说明: 北航Clubs的初衷是服务社团,服务学生,满足社团与学生的信息互通的需求.社团管理运营方便的需求. 建设网站的目的是使学生可以在一个权威可信的网站上获取到社团实时的动态,社团活动的 ...
- “北航Clubs”项目汇报
一.项目展示 二.用户的痛点与需求 1.北航学生,在百团大战之后,很难再有渠道加入社团,了解社团活动,简直如蒙在鼓里! 2.当你周末想参加一些活动,充实一下枯燥的求学生活时,却发现不知道有哪些社团有活 ...
- “北航Clubs” Alpha版发布!
一.功能 1.获取活动信息: 用户进入网站后,第一眼就可以查看到近期活动 2.查看活动详情 点击活动标题,可以进入活动详情页面 3.注册功能 首页点击注册,输入学号.密码.姓名.手机号即可完成注册 4 ...
- “北航Clubs” Beta版本开发目标
Beta版本开发目标 总体设想:修复Alpha版本中的若干bug,并在Alpha版本成果之上进行进一步开发,实现社员管理.评论.站内信等功能. 1.对Alpha版本功能的更新与加强 后端实现从SQLi ...
- java转换 HTML字符实体,java特殊字符转义字符串
为什么要用转义字符串? HTML中<,>,&等有特殊含义(<,>,用于链接签,&用于转义),不能直接使用.这些符号是不显示在我们最终看到的网页里的,那如果我们希 ...
- 【转载学习前辈的经验】-- Mistakes I made (as a developer) 我(作为一名开发者)所犯过的错误
我 2006 年开始工作,至今已经 10 年.10 年是个里程碑,我开始回顾自己曾经犯过的错误,以及我希望从同行那里得到什么类型的忠告.一切都在快速改变,10 年了,我不能确定这些秘诀是否还有用. 不 ...
- HTML CSS 特殊字符表(转载)
转载地址:http://blog.csdn.net/bluestarf/article/details/40652011 转载原文地址:http://zhengmifan.com/news/noteb ...
- C++-数据库【1】-C++连接MSSQL数据库
测试环境—— 系统:Win7 64bit 编译器:VC++ 2015 数据库:MSSQL 2008 R2 #include <Windows.h> #include <stdio.h ...
- 《Entity Framework 6 Recipes》中文翻译系列 (23) -----第五章 加载实体和导航属性之预先加载与Find()方法
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-2 预先加载关联实体 问题 你想在一次数据交互中加载一个实体和与它相关联实体. ...
随机推荐
- sarama的消费者组分析、使用
以前老的sarama版本不支持消费者组的消费方式,所以大多数人都用sarama-cluster. 后来sarama支持了消费者组的消费方式,sarama-cluster也停止维护了,但网上关于sara ...
- 阿里云函数计算发布新功能,支持容器镜像,加速应用 Serverless 进程
我们先通过一段视频来看看函数计算和容器相结合后,在视频转码场景下的优秀表现.点击观看视频 >> FaaS 的门槛 Serverless 形态的云服务帮助开发者承担了大量复杂的扩缩容.运维. ...
- Java秘诀!Java关系运算符介绍
运算符丰富是 Java 语言的主要特点之一,它提供的运算符数量之多,在高级语言中是少见的. Java 语言中的运算符除了具有优先级之外,还有结合性的特点.当一个表达式中出现多种运算符时,执行的先后顺序 ...
- Linux系统安装MySql5.7并通过sql脚本导入数据
为了下载到的MySQL版本和目标系统相互兼容,在开启之前,最好了解目标系统的相关信息. 查询系统版本: cat /etc/issue 查看系统位数 getconf LONG_BIT 选择MySQL 根 ...
- Markdown Reference
Markdown For Typora Overview Markdown is created by Daring Fireball; the original guideline is here. ...
- GPIO位带操作点亮LED,且使用按键控制开关
1. 项目 类似与C51单片机的位操作使能引脚来点亮LED. 例如,sbit P0^0 = 0 LED1 = P0^0; 2. 代码 main.c #include "stm32f10x.h ...
- 【UE4】基础概念——文件结构、类型、反射、编译、接口、垃圾回收、序列化
新标签打开或者下载看大图 思维导图 Engine Structure Pipeline Programming Pipeline Blueprint Pipeline
- Java:LinkedHashMap类小记
Java:LinkedHashMap类小记 对 Java 中的 LinkedHashMap类,做一个微不足道的小小小小记 概述 public class LinkedHashMap<K,V> ...
- 移动端 h5 uniapp 读,写,删本地文件或sd文件
移动端 h5 uniapp 读,写,删本地文件或sd文件 应用场景: 当我们需要做离线应用或者是加载本地文件时使用到此方法.(本篇文章给大家分享访问app私有文件目录,系统公共目录,sd外置存储的文件 ...
- 嵌入式单片机之stm32串口你懂了多少!!
stm32作为现在嵌入式物联网单片机行业中经常要用多的技术,相信大家都有所接触,今天这篇就给大家详细的分析下有关于stm32的出口,还不是很清楚的朋友要注意看看了哦,在最后还会为大家分享有些关于stm ...