题意:从原点出发,走\(n\)次,每次往四个方向中随机一个走,走每个方向有个概率,求所有方案走到过的点数的方差。

题解:orz kczno1

\(E*all=\sum (a_i-avg)^2*all=\sum a_i^2-2*\sum a_i*avg+avg^2*all*all\)。把\(avg=\frac{\sum a_i}{all}\)代入,可以发现要求的就是\(\sum a_i\)和\(\sum a_i^2\)。以下为了方便求概率。

设\(f_{i,x,y}\)为走了\(i\)步第一次走到\(x,y\)的概率,\(g_{i,x,y}\)为走了\(i\)步最后在\(x,y\)的概率,\(g\)可以暴力DP,\(f\)用\(g\)容斥一下就行了。\(\sum a_i\)显然可以拆成对于每个点,求出经过它的概率并求和,就是\(\sum f\)。

考虑怎样求\(\sum a_i^2\)。可以用类似管道取珠的方法,把\(x^2\)拆成\(\binom{x}{2}*2+x\),那么只要求\(\sum \binom{x}{2}\)。设\(h_{i,x,y}\)为走了\(i\)步第一次走到某个点\(a,b\)并且之前走到过\(a-x,b-y\)的概率和,那么\(h_{i,x,y}=\sum_{j<i,a,b}f_{j,a,b}f_{i-j,x,y}-\sum_{j<i}h_{j,-x,-y}f_{i-j,x,y}\),减掉的是第一次到达某个点\(a,b\)之前到达过\(a+x,b+y\)的概率。

再加一些卡常就uojrk2了。注意用16次一取膜优化的时候要保证每一次加的都为非负数,否则要改为(signed) long long并且改为8次一取膜。一开始因为这个WA飞了。

#include<bits/stdc++.h>
using namespace std;
const int mod = 998244353;
const int N = 110;
typedef long long ll; int qpow(int a, int b) {
int ret = 1;
while(b) {
if(b & 1) {
ret = 1ll * ret * a % mod;
}
a = 1ll * a * a % mod, b >>= 1;
}
return ret;
} int n, w[4], tt = 0, f[N][N * 2][N * 2], g[N][N * 2][N * 2], h[N][N * 2][N * 2], sf[N], dx[4] = {0, 0, -1, 1}, dy[4] = {1, -1, 0, 0}, s1 = 0, s2 = 0; int main() {
cin >> n;
for(int i = 0; i < 4; i++) {
cin >> w[i], tt += w[i];
}
for(int i = 0; i < 4; i++) {
w[i] = 1ll * w[i] * qpow(tt, mod - 2) % mod;
}
f[0][N][N] = g[0][N][N] = sf[0] = 1;
for(int i = 1; i <= n; i++)
for(int x = -i; x <= i; x++)
for(int y = -i; y <= i; y++) {
if(abs(x) + abs(y) > i) {
continue;
}
ll sum = 0;
for(int k = 0; k < 4; k++) {
sum += 1ll * g[i - 1][x - dx[k] + N][y - dy[k] + N] * w[k];
}
g[i][x + N][y + N] = sum % mod;
sum = g[i][x + N][y + N];
for(int k = 0; k < i; k++) {
sum -= 1ll * f[k][x + N][y + N] * g[i - k][N][N];
if((k & 7) == 7) {
sum %= mod;
}
}
f[i][x + N][y + N] = (sum % mod + mod) % mod;
sf[i] = (sf[i] + f[i][x + N][y + N]) % mod;
sum = 0;
for(int k = 0; k < i; k++) {
sum += 1ll * (sf[k] - h[k][-x + N][-y + N]) * f[i - k][x + N][y + N];
if((k & 7) == 7) {
sum %= mod;
}
}
h[i][x + N][y + N] = (sum % mod + mod) % mod;
}
for(int i = 0; i <= n; i++) {
s1 = (s1 + sf[i]) % mod;
}
for(int i = 0; i <= n; i++)
for(int x = -i; x <= i; x++)
for(int y = -i; y <= i; y++) {
if(abs(x) + abs(y) > i) {
continue;
}
s2 = (s2 + h[i][x + N][y + N]) % mod;
}
tt = qpow(tt, n);
s1 = 1ll * s1 * tt % mod, s2 = 1ll * s2 * tt % mod;
cout << ((1ll * tt * (2ll * s2 + s1) - 1ll * s1 * s1) % mod + mod) % mod;
return 0;
}

[UOJ211][UER #6]逃跑的更多相关文章

  1. 【BZOJ-1340】Escape逃跑问题 最小割

    1340: [Baltic2007]Escape逃跑问题 Time Limit: 5 Sec  Memory Limit: 162 MBSubmit: 264  Solved: 121[Submit] ...

  2. code vs 1026 逃跑的拉尔夫

    1026 逃跑的拉尔夫  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 黄金 Gold 题解       题目描述 Description 年轻的拉尔夫开玩笑地从一个小镇上偷走 ...

  3. AC日记——逃跑的拉尔夫 codevs 1026 (搜索)

    1026 逃跑的拉尔夫  时间限制: 1 s    空间限制: 128000 KB    题目等级 : 黄金 Gold 题解       题目描述 Description   年轻的拉尔夫开玩笑地从一 ...

  4. 【UER #1】[UOJ#12]猜数 [UOJ#13]跳蚤OS [UOJ#14]DZY Loves Graph

    [UOJ#12][UER #1]猜数 试题描述 这一天,小Y.小D.小C正在愉快地玩耍. 小Y是个数学家,他一拍脑袋冒出了一个神奇的完全平方数 n. 小D是个机灵鬼,很快从小Y嘴里套出了 n的值.然后 ...

  5. 程序设计: 猫大叫一声,所有的老鼠都开始逃跑,主人被惊醒。(C#语言)

    要求:  1.要有联动性,老鼠和主人的行为是被动的.  2.考虑可扩展性,猫的叫声可能引起其他联动效应. 我么能事件来一步一步来实现: 将要执行的老鼠逃跑,和主人惊醒的行为注册到事件中,猫叫之后引发事 ...

  6. UOJ #142. 【UER #5】万圣节的南瓜灯 并查集

    #142. [UER #5]万圣节的南瓜灯 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://uoj.ac/problem/142 Descrip ...

  7. uoj #139. 【UER #4】被删除的黑白树 dfs序 贪心

    #139. [UER #4]被删除的黑白树 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://uoj.ac/problem/139 Descript ...

  8. 逃跑(escape)

    逃跑(escape) 时间限制: 3 Sec  内存限制: 128 MB 题目描述 输入 第一行是5个正整数,n,m,k,S,T,分别代表无向图点数,边数,蝙蝠的数量,二小姐所在起点的编号,目标点的编 ...

  9. FJNU2018低程A 逃跑路线(Lucas + 中国剩余定理 + LGV定理)题解

    题目描述 n个人在w*h的监狱里面想要逃跑,已知他们的同伙在坐标(bi,h)接应他们,他们现在被关在(ai,1)现在他们必须要到同伙那里才有逃出去的机会,这n个人又很蠢只会从(x,y)->(x+ ...

随机推荐

  1. Free Pascal User’s Guide

    https://www.freepascal.org/docs-html/current/user/user.html

  2. 打印流PrintWriter

    * 打印流 * 字节流打印流 PrintStream * 字符流打印流PrintWriter * * 打印流的特点: * A:只有写数据的,没有读取数据,只能操作目的地,不能操作数据源 * * B:可 ...

  3. MVC 源码系列之路由(一)

    路由系统 注释:这部分的源码是通过Refector查看UrlRoutingModule的源码编写,这部分的代码没有写到MVC中,却是MVC的入口. 简单的说一下激活路由之前的一些操作.一开始是由MVC ...

  4. 刷题——一道全排列的题目(Permutations)

    题目内容: 思路其实很简单,那就是暴力交换顺序,直接迭代出所有可能.先在一个位置固定一个数字,然后对剩下的数字进行排列,用同样的方法对剩下的数字进行排列(因此要用到递归,不用也行,但是会复杂一点,这里 ...

  5. 取消a或input标签聚焦后出现虚线框

    1:在a标签里加入js控制,当a标签被聚焦时,强制取消焦点,这时候a标签自然不会有虚线框. <a href="#" onfocus="this.blur();&qu ...

  6. REACT--》fetch---基本使用

    [WangQI]---fetch---基本使用   一.fetch fetch是一种XMLHttpRequest的一种替代方案,在工作当中除了用ajax获取后台数据外我们还可以使用fetch.axio ...

  7. Java相关面试题总结+答案(七)

    [Hibernate] 113. 为什么要使用 hibernate? hibernate 是对 jdbc 的封装,大大简化了数据访问层的繁琐的重复性代码. hibernate 是一个优秀的 ORM 实 ...

  8. CentOS7 redhat7 linux系统1分钟安装Zabbix web 监控 服务器

    一.准备工作OS:centos7.4Zabbix version:3.4.6(2018/1/15日上线的新版本)Database:MariaDB关闭防火墙:systemctl stop firewal ...

  9. [Web 前端] 012 css 元素溢出

    overflow 当子元素的尺寸超过父元素的尺寸时,需要设置父元素显示溢出的子元素的方式 通过 overflow 属性来设置 概览 参数 释义 visible(默认值) 内容不会被修剪会呈现在元素框之 ...

  10. 创建Maven项目时,出现系列的错误提示的修改方法

    1.创建Maven项目成功之后,需要修改一些配置, (1).java版本改为“本系统中java的版本号” 问题一:(2).Dynamic Web Module的version要改为2.5以上,然而本人 ...