首页 > 其他分享 >20201203 T1 color

20201203 T1 color

时间:2022-12-04 16:12:31浏览次数:74  
标签:ifac color ll T1 int 20201203 ans fac MOD

题目描述

给定一个 \(n\) 个点的环,初始时全为白色,每次有两种操作:

  1. 随机选一个点(可能为黑),把它变成黑色,代价为 \(1\);

  2. 选一个点,若其在环上相邻两点都为黑色,则可把它变成黑色。

求把所有点变黑期望代价,对 \(998244353\) 取模。

\(2 \le n \le 10^5\)

题解

现场得分:0/10(写的拆分数暴力,结果 n = 2 WA 了,然后还打包……)

首先观察到 2 操作不受操作顺序影响,且可以无限操作,于是将问题转化成:

不存在两个白点相邻的期望代价

相邻两个黑点距离 \(< 2\) 的期望代价

考虑将代价转化一下:\(\sum_\limits{i=1} i * E_i = \sum_\limits{i=1}E'_i\),\(E'_i\) 为代价 \(\ge i\) 的概率。

我们发现这个随机选点,选到了已经选过的黑点是没有用的,于是定义已经染色了 \(i\) 个点,现在去染第 \(i+1\) 个点的期望代价,显然为 \(\frac{n}{n - i}\)。

考虑如何计算 \(E'_i\),考虑容斥,即 \(E'_i=1-\frac{f_i}{sum_i}\),\(f_i\) 为 \(i\) 次成功染色且已经为结束态的方案数,\(sum_i\) 为 \(i\) 次成功染色的总方案数。

考虑计算 \(f_i\),相当于是环上 \(i\) 个黑点中插入 \(n - i\) 个白点,且中间最多插 \(1\) 个。所以 \(f_i = C(i, n - i)\)。

考虑计算 \(sum_i\), 由于是环,所以我们得避免算重,我们不妨钦定成功染色的 \(i\) 个点中包含第 \(1\) 个点,所以 \(sum_i = C(n - 1, i - 1)\)。

代码

#include <bits/stdc++.h>
#define SZ(x) (int) x.size() - 1
#define all(x) x.begin(), x.end()
#define ms(x, y) memset(x, y, sizeof x)
#define F(i, x, y) for (int i = (x); i <= (y); i++)
#define DF(i, x, y) for (int i = (x); i >= (y); i--)
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
template <typename T> void chkmax(T &x, T y) {x = max(x, y); }
template <typename T> void chkmin(T &x, T y) {x = min(x, y); }
template <typename T> void read(T &x) {
	x = 0; int f = 1; char c = getchar();
	for (; !isdigit(c); c = getchar()) if (c == '-') f = -f;
	for (; isdigit(c); c = getchar()) x = x * 10 + c - '0';
	x *= f;
}
const int N = 1e5 + 10, MOD = 998244353;
int n, f[N];
int fac[N], ifac[N];
inline void init(int n) {
	fac[0] = fac[1] = ifac[0] = ifac[1] = 1;
	F(i, 2, n) fac[i] = (ll) fac[i - 1] * i % MOD, ifac[i] = (ll) (MOD - MOD / i) * ifac[MOD % i] % MOD;
	F(i, 2, n) ifac[i] = (ll) ifac[i] * ifac[i - 1] % MOD;
}
inline int C(int x, int y) {
	if (x < y || y < 0) return 0;
	return (ll) fac[x] * ifac[y] % MOD * ifac[x - y] % MOD;
}
inline int Quickpow(int x, int y) {
	int ans = 1;
	for (; y; x = (ll) x * x % MOD,y >>= 1)
		if (y & 1) ans = (ll) ans * x % MOD;
	return ans;
}
int ans;
signed main() {
	freopen("color.in", "r", stdin);
	freopen("color.out", "w", stdout);
	read(n);
	init(1e5);
	F(i, 1, n) ans = (ans + (1 - (ll) C(i, n - i) * Quickpow(C(n - 1, i - 1), MOD - 2) % MOD + MOD) * n % MOD * Quickpow(n - i, MOD - 2)) % MOD;
	cout << (ans + 1) % MOD;
	return 0;
}

标签:ifac,color,ll,T1,int,20201203,ans,fac,MOD
From: https://www.cnblogs.com/zhaohaikun/p/16950034.html

相关文章

  • NOIP2022 T1 种花 题解
    Part1吐槽&退役寄考场上唯一AC的题目,T3看错题以为可以删去不止1条边,T4输出没换行,寄。最后喜提100+0+0+0,给我的OI生涯画上了一个不完美的句号。Part2题解题目让统计......
  • 【CV项目实现】交通标志数据集TT100K简介
    前言论文是​​清华-腾讯联合实验室​​提出的,公开了Tsinghua‐Tencent100K数据集,创建了一个大型交通标志基准。该数据集提供了100000张分辨率为2048像素×2048像素、包含......
  • [论文阅读] 颜色迁移-Correlated Color Space
    [论文阅读]颜色迁移-CorrelatedColorSpace文章:Colortransferincorrelatedcolorspace,[paper],[matlabcode],[opencvcode]1-算法原理本文算法比较简单,......
  • 取色器TakeColor8.0 CN Green下载
    关注微信公众号【工控羊】或者微信号【gksheep】,微信公众号后台输入数字编号【1011】即可获取下载链接。......
  • NSSCTF周赛Misc-hint1
    O​​​​‎‏‎​​​​‎‏‍​​​​‏‎​​​​​‏​‌​​​​‍​‏​​​​‍​‍​​​​‌‏‌​​​​‏​​​​​​‏​‌​​​​‎‏‏​​​​‏‍‌​​......
  • test1
    安装hexo安装hexo之前需要安装Nodejs组件,这个在我的另一篇文章:Hexo是我们博客的框架,我们需要在我们的电脑里创建一个文件夹,可以命名为Blog,Hexo框架与你发布的博客网页以......
  • 杭州集训D4T1
    题目简述给定一个大小为\(n\left(n\le10^5\right)\)的环,每个点初始为白色,每一步在所有点中均匀随机选择一个,将其染黑(已经黑则不变);然后对于所有白点,如果其左右都是黑色,那......
  • 题解【CF1592F2 Alice and Recoloring 2】
    CF1592F2AliceandRecoloring2解题报告。不一定更好的阅读体验。摘自我的构造题目选做例题IV。CF2800的构造就这?/cf/cf/cf(首先,操作2和操作3都是没有用......
  • react18中useCallback与memo使用
     1、父组件Demo3Count组件缓存有两种方法a、  b、    2、子组件    3、效果3.1、初始均渲染  3.2、点击b......
  • SAP MM 为UB类型的STO执行VL10B,报错-没有项目类别表存在(表T184L NL 0002 V)-之对策
    SAPMM 为UB类型的STO执行VL10B,报错-没有项目类别表存在(表T184LNL0002V)-之对策  业务人员创建好了UB类型的转储单据后,试图执行事务代码VL10B,未能成功,报错如下:......