【BZOJ1416/1498】【NOI2006】神奇的口袋(数论,概率)

题面

BZOJ1416

BZOJ1498

洛谷

题面都是图片形式是什么鬼。。

题解

考虑以下性质

1.\(x[1],x[2]..x[n]\)等价于\(1,2,...n\)

证明:

假设取第\(k\)步以前,所有的球的个数分别是\(a[1],a[2]..a[n]\),

球的总数是\(sum\)

那么,第\(k\)步取到颜色\(y\)的概率是\(\frac{a[y]}{sum}\)

考虑第\(k+1\)步取到颜色\(y\)的概率

①第\(k\)步取了颜色\(y\)

那么,\(k+1\)步取到\(y\)的概率是\(\frac{a[y]}{sum}*\frac{a[y]+D}{sum+D}\)

②第\(k\)步没有取到颜色\(y\)

那么,\(k+1\)步取到\(y\)的概率是\(\frac{sum-a[y]}{sum}*\frac{a[y]}{sum+D}\)

将概率相加,得到第\(k+1\)步的概率

\[\frac{a[y](a[y]+D)+(sum-a[y])a[y]}{sum(sum+D)}
\]

\[=\frac{a[y](sum+D)}{sum(sum+D)}=\frac{a[y]}{sum}
\]

因此,在没有其他限制下,无论何时取\(y\)的概率都是相等的

也就是题目中按照\(x\)排序之后,可以直接将\(x\)离散。

但是题目中显然存在其他限制,也就是前面的某一次必定会取到某个颜色,所以我们来考虑另外一个性质。

颜色出现的顺序对答案没有影响

对于按照\(x\)排序之后,相邻的两个\(y[i],y[i+1]\)

①\(y[i]=y[i+1]\),显然没有影响

②\(y[i]\neq y[i+1]\)

考虑概率

\[P1=\frac{a[y[i]]}{sum}*\frac{a[y[i+1]]}{sum+D}
\]

交换之后考虑概率

\[P2=\frac{a[y[i+1]]}{sum}*\frac{a[y[i]]}{sum+D}
\]

\(P1\)显然等于\(P2\)

因此,\(y\)的出现顺序与结果无关。

根据上面的两个性质,我们可以得出:

1.\(x\)可以直接离散

2.\(y\)的顺序对结果并没有影响

因此,我们可以就按照读入顺序处理,并且\(x\)读进来并没有什么用

记录一下每一个颜色的球个数,以及球的总数

每次要抽到一个颜色的球就给他的数量以及总数都加上\(D\)

然后算一下概率就行了

因此范围比较大,概率要用高精度算

为了防止要写高精度除法

可以先分解质因数,然后约掉之后再做乘法就行了。

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<set>
#include<map>
#include<vector>
#include<queue>
using namespace std;
#define ll long long
#define RG register
#define MAX 1111
inline int read()
{
RG int x=0,t=1;RG char ch=getchar();
while((ch<'0'||ch>'9')&&ch!='-')ch=getchar();
if(ch=='-')t=-1,ch=getchar();
while(ch<='9'&&ch>='0')x=x*10+ch-48,ch=getchar();
return x*t;
}
struct BigInt
{
int s[20000],ws;
void init(){s[1]=1;ws=1;}
void Multi(int x)
{
for(int i=1;i<=ws;++i)s[i]=s[i]*x;
for(int i=1;i<=ws;++i)s[i+1]+=s[i]/10,s[i]%=10;
while(s[ws+1])++ws,s[ws+1]=s[ws]/10,s[ws]%=10;
}
void output(){for(int i=ws;i;--i)printf("%d",s[i]);}
}Ans1,Ans2;
int pri[20001],tot;
bool zs[20001];
void getpri()
{
zs[1]=true;
for(int i=2;i<=20000;++i)
{
if(!zs[i])pri[++tot]=i;
for(int j=1;j<=tot&&i*pri[j]<=20000;++j)
{
zs[i*pri[j]]=true;
if(i%pri[j]==0)break;
}
}
}
int Mul[20001],Div[20001];
int sum,a[MAX];
int n,m,D;
void Calc(int x,int *f)
{
for(int i=1;i<=tot;++i)
while(x%pri[i]==0)
{
f[pri[i]]++;
x/=pri[i];
}
}
int main()
{
n=read();m=read();D=read();
for(int i=1;i<=n;++i)a[i]=read(),sum+=a[i];
getpri();
for(int i=1;i<=m;++i)
{
int x=read(),y=read();
if(!a[y]){puts("0/1");return 0;}
Calc(a[y],Mul);Calc(sum,Div);
a[y]+=D;sum+=D;
}
for(int i=1;i<=20000;++i)
if(Div[i]>=Mul[i])Div[i]-=Mul[i],Mul[i]=0;
else Mul[i]-=Div[i],Div[i]=0;
Ans1.init();Ans2.init();
for(int i=1;i<=20000;++i)
for(int j=1;j<=Mul[i];++j)Ans1.Multi(i);
for(int i=1;i<=20000;++i)
for(int j=1;j<=Div[i];++j)Ans2.Multi(i);
Ans1.output();putchar('/');Ans2.output();puts("");
return 0;
}

【BZOJ1416/1498】【NOI2006】神奇的口袋(数论,概率)的更多相关文章

  1. BZOJ 1416: [NOI2006]神奇的口袋( 高精度 )

    把x1~xn当成是1~n, 答案是不会变的. 然后直接模拟就行了...... P.S 双倍经验... BZOJ1416 && BZOJ1498 -------------------- ...

  2. ●BZOJ 1416 [NOI2006]神奇的口袋

    题链: http://www.lydsy.com/JudgeOnline/problem.php?id=1416题解: Pòlya瓦罐模型: 给定罐子里每种颜色的球的个数A[i],按题目要求随机操作若 ...

  3. Bzoj1498&1416: [NOI2006]神奇的口袋

    什么鬼双倍经验题??? Sol 考虑在第\(k\)次摸到\(y\)的概率 如果上次摸到\(y\),目前有\(sum\)个球,\(y\)有\(a[y]\)个,那么概率就是\(\frac{a[y]+d}{ ...

  4. 神奇的口袋(dp)

    有一个神奇的口袋,总的容积是40,用这个口袋可以变出一 些物品,这些物品的总体积必须是40. John现在有n(1≤n ≤ 20)个想要得到的物品,每个物品 的体积分别是a1,a2……an.John可 ...

  5. [codeup] 2044 神奇的口袋

    题目描述 有一个神奇的口袋,总的容积是40,用这个口袋可以变出一些物品,这些物品的总体积必须是40.John现在有n个想要得到的物品,每个物品的体积分别是a1,a2--an.John可以从这些物品中选 ...

  6. dp 神奇的口袋

    有一个神奇的口袋,总的容积是40,用这个口袋可以变出一 些物品,这些物品的总体积必须是40.  John现在有n(1≤n ≤ 20)个想要得到的物品,每个物品 的体积分别是a1,a2--an.Joh ...

  7. 九度OJ 1114:神奇的口袋 (DFS、DP)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:948 解决:554 题目描述: 有一个神奇的口袋,总的容积是40,用这个口袋可以变出一些物品,这些物品的总体积必须是40.John现在有n个 ...

  8. 九度oj 题目1114:神奇的口袋

    题目描述: 有一个神奇的口袋,总的容积是40,用这个口袋可以变出一些物品,这些物品的总体积必须是40.John现在有n个想要得到的物品,每个物品的体积分别是a1,a2……an.John可以从这些物品中 ...

  9. 百练2755:神奇的口袋(简单dp)

    描述有一个神奇的口袋,总的容积是40,用这个口袋可以变出一些物品,这些物品的总体积必须是40.John现在有n个想要得到的物品,每个物品的体积分别是a1,a2……an.John可以从这些物品中选择一些 ...

随机推荐

  1. hive 数据导入

    Hive的几种常见的数据导入方式这里介绍四种:(1).从本地文件系统中导入数据到Hive表:(2).从HDFS上导入数据到Hive表:(3).从别的表中查询出相应的数据并导入到Hive表中:(4).在 ...

  2. Selenium2+python自动化-CSS定位语法

    前言 一些人在使用selenium定位元素时,用的是xpath定位,因为xpath基本能解决定位的需求.css定位往往被忽略掉了,其实css定位也有它的价值,css定位更快,语法更简洁.这一篇css的 ...

  3. 【UGUI】 (一)------- 放大镜

    在许多游戏或应用中,我们常常看到放大镜的身影,而在Unity里面,制作一个简易的放大镜是非常简单的.    一. 创建一个3DObject 创建一个Cube或者 Cylinder,这里为了更像放大镜一 ...

  4. ES6的新特性(9)——对象的扩展

    对象的扩展 属性的简洁表示法 ES6 允许直接写入变量和函数,作为对象的属性和方法.这样的书写更加简洁. const foo = 'bar'; const baz = {foo}; baz // {f ...

  5. Python Pygame (3) 界面显示

    显示模式: 之前使display模块的set_mode()的方法用来指定界面的大小,并返回一个Surface对象. set_mode()的原型如下: display.set_mode(resoluti ...

  6. Scrum立会报告+燃尽图(Beta阶段第二周第七次)

    此作业要求参见:https://edu.cnblogs.com/campus/nenu/2018fall/homework/2415 项目地址:https://coding.net/u/wuyy694 ...

  7. 团队计划会议(二)——WBS

    一.会议及WBS 因为是第一次开发android应用,所以我们对这次开发心里也没底,最后我们商量暂时先实现主要的几个骨架功能,之后再慢慢完善. 会议期间,我们根据自己的能力大致先估算了完成这些功能需要 ...

  8. 每日Scrum--No.2

    Yesterday:找地图 Today: 找到最适合我们软件的地图版本 Problem:找不到特别匹配的版本

  9. Learn Docker(一)—软件安装与常规操作

    一.安装Docker Windows平台 在Windows10 X64专业版上可以直接下载Docker原生应用进行安装,在控制面板的程序与功能里启用Hyper-v,之后就可以运行docker程序啦. ...

  10. VS2013安装及单元测试

    aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAZ0AAAIlCAIAAACBzLJwAAAACXBIWXMAAA7EAAAOxAGVKw4bAAAgAE ...