首页
Python
Java
IOS
Andorid
NodeJS
JavaScript
HTML5
【
【洛谷P3600】 随机数生成器
】的更多相关文章
洛谷P3600 随机数生成器(期望dp 组合数)
题意 题目链接 Sol 一条重要的性质:如果某个区间覆盖了另一个区间,那么该区间是没有用的(不会对最大值做出贡献) 首先不难想到枚举最终的答案\(x\).这时我们需要计算的是最大值恰好为\(x\)的概率. 发现不是很好搞,我们记\(P(x)\)表示最大值\(\leqslant x\)的概率,那么恰好为\(x\)的概率为\(P(x) - P(x - 1)\) 计算概率可以直接用定义:合法的方案/总方案(\(x^n\)) 考虑如何计算合法方案:我们直接去枚举在询问区间中有多少个点\(\leqslan…
洛谷P3600随机数生成器——期望+DP
原题链接 写到一半发现写不下去了... 所以orz xyz32768,您去看这篇题解吧,思路很清晰,我之前写的胡言乱语与之差距不啻天渊 #include <algorithm> #include <iostream> #include <cstdlib> #include <cstring> #include <cstdio> #include <random> #include <string> #include <…
洛谷 P3600 - 随机数生成器(期望 dp)
题面传送门 我竟然独立搞出了这道黑题!incredible! u1s1 这题是我做题时间跨度最大的题之一-- 首先讲下我四个月前想出来的 \(n^2\log n\) 的做法吧. 记 \(f(a)=\max\limits_{i=1}^q\min\limits_{j=l_i}^{r_i}a_j=x\) 首先期望转概率,设 \(p_i\) 表示 \(f(a)=x\) 的概率,答案即为 \(\sum p_i\times i\). 注意到这题直接求 \(f(a)=x\) 的概率不是特别容易,故考虑换个思路…
[洛谷P5147]随机数生成器
题目大意:$$f_n=\begin{cases}\frac{\sum\limits_{i=1}^nf_i}n+1&(n>1)\\0&(n=1)\end{cases}$$求$f_n(n<2^{31})$ 题解:考虑$n>2$时的情况. $$f_n=\dfrac{\sum\limits_{i=1}^nf_i}n+1\\nf_n=\sum\limits_{i=1}^{n-1}f_i+f_n+n\\\begin{align}(n-1)f_n=\sum\limits_{i=1}^{…
洛谷P3306 随机数生成器
题意:给你一个数列,a1 = x,ai = (A * ai-1 + B) % P,求第一个是t的是哪一项,或者永远不会有t. 解:循环节不会超过P.我们使用BSGS的思想,预处理从t开始跳√P步的,插入Hash表内. 然后每次把a1跳√P步,来看是否在Hash表中存在. 这样发现我们有40,WA了60分.为什么呢?考虑是否存在两个数x和y,它们跳一次之后一样了.发现这种情况只会出现在A = 0的时候,于是特判掉A = 0.可获得100分. #include <bits/stdc++.h> ;…
Luogu P3600 随机数生成器
Luogu P3600 随机数生成器 题目描述 sol研发了一个神奇的随机数系统,可以自动按照环境噪音生成真·随机数. 现在sol打算生成\(n\)个\([1,x]\)的整数\(a_1...a_n\),然后进行一些询问. \(q\)次询问,每次询问i有两个参数\(li\)和\(ri\),sol会计算\(\min_{li \leq j \leq ri} a_j\)(a数组中下标在\(li.ri\)之间的数的最小值). 最后测试结果会是这些询问得到的结果的最大值. sol进行了很多次实验,现在他想问…
P3600 随机数生成器
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/转载请注明出处,侵权必究,保留最终解释权! 题目链接:洛谷3600 正解:概率DP 解题报告: 官方题解:戳这里 考虑最朴素的计算式就是:$\sum_{i=1}^{x} i*P(ans=i) $为所求. 上式又等于$\sum_{i=1}^{x} P(ans>=i)$,这个可以理解成对于$j>=i$…
【洛谷P3600】 随机数生成器
https://www.luogu.org/problem/show?pid=3600#sub (题目链接) 题意 一个$n$个数的序列,里面每个数值域为$[1,X]$.给$q$个区间,每个区间的权值为这段区间里面的最小的数,然后算出了一个$ans=min(q_i)$,问$ans$的期望大小. Solution md,太久没写题了,菜的抠脚了已经. 官方题解写的挺好的:https://www.luogu.org/discuss/show?postid=7867 细节 删除包含区间. 代码 //…
Luogu P3600 随机数生成器(期望+dp)
题意 有一个长度为 \(n\) 的整数列 \(a_1, a_2, \cdots, a_n\) ,每个元素在 \([1, x]\) 中的整数中均匀随机生成. 有 \(q\) 个询问,第 \(i\) 个询问的结果是下标在 \([l_i , r_i ]\) 的元素的最小值. 求这 \(q\) 个询问结果的最大值的期望,\(\bmod 666623333\) . 数据范围 \(1 \le n, q, x \le 2000\) . 题解 参考了 fjzzq2002 的题解. 有个很有用的结论. 对于非负实…
luogu P3600 随机数生成器【dp】
把期望改成方案数最后除一下,设h[i]为最大值恰好是i的方案数,那么要求的就是Σh[i]*i 首先包含其他区间的区间是没有意义的,用单调栈去掉 然后恰好不好求,就改成h[i]表示最大值最大是i的方案数,求Σ(h[i]-h[i-1])*i即可 然后考虑h怎么求,\( h[i]=\sum_{j=1}^{n}i^j*(m-1)^{n-j}*选j个点使得每个区间都有一个选中点 \) 设选j个点使得每个区间都有一个选中点为g[j],设f[i][j]为前i个必选i点一共选j个点的方案数,那么\( g[j]=…