求n-1个数的和;量不定,概率相等;
来源:互联网 发布:中兴手机在线升级软件 编辑:程序博客网 时间:2024/04/28 15:16
测试用例设计:正交实验。
有n个数,求所有n-1个数的和。要求算法复杂度为0(n)。
a0, a1, a2, a3, a4, ..... an
1, a0, a0+a1,a0+a1+a2,..... 之后,在翻转过来,加到头即可。
“给出一个数据流,这个数据流的长度很大或者未知。并且对该数据流中数据只能访问一次。请写出一个随机选择算法,使得数据流中所有数据被选中的概率相等。”
蓄水池算法
如前面所说,对这个问题我们首先从最简单的例子出发:数据流只有一个数据。我们接收数据,发现数据流结束了,直接返回该数据,该数据返回的概率为1。看来很简单,那么我们试试难一点的情况:假设数据流里有两个数据。
我们读到了第一个数据,这次我们不能直接返回该数据,因为数据流没有结束。我们继续读取第二个数据,发现数据流结束了。因此我们只要保证以相同的概率返回第一个或者第二个数据就可以满足题目要求。因此我们生成一个0到1的随机数R,如果R小于0.5我们就返回第一个数据,如果R大于0.5,返回第二个数据。
接着我们继续分析有三个数据的数据流的情况。为了方便,我们按顺序给流中的数据命名为1、2、3。我们陆续收到了数据1、2和前面的例子一样,我们只能保存一个数据,所以必须淘汰1和2中的一个。应该如何淘汰呢?不妨和上面例子一样,我们按照二分之一的概率淘汰一个,例如我们淘汰了2。继续读取流中的数据3,发现数据流结束了,我们知道在长度为3的数据流中,如果返回数据3的概率为1/3,那么才有可能保证选择的正确性。也就是说,目前我们手里有1,3两个数据,我们通过一次随机选择,以1/3的概率留下数据3,以2/3的概率留下数据1.那么数据1被最终留下的概率是多少呢?
- 数据1被留下:(1/2)*(2/3) = 1/3
- 数据2被留下概率:(1/2)*(2/3) = 1/3
- 数据3被留下概率:1/3
这个方法可以满足题目要求,所有数据被留下返回的概率一样!
因此,我们做一下推论:假设当前正要读取第n个数据,则我们以1/n的概率留下该数据,否则留下前n-1个数据中的一个。以这种方法选择,所有数据流中数据被选择的概率一样。简短的证明:假设n-1时候成立,即前n-1个数据被返回的概率都是1/n-1,当前正在读取第n个数据,以1/n的概率返回它。那么前n-1个数据中数据被返回的概率为:(1/(n-1))*((n-1)/n)= 1/n,假设成立。
- 求n-1个数的和;量不定,概率相等;
- 求 n元一次不定方程 解的个数 的 两个版本和n种实现方法
- 从未知大小的n个数中取m个数,使各数被取出的概率相等
- 求n个数的和
- 求n个数的阶乘的和
- 求n的因子的个数和。.
- 算法题:求N!末尾0的个数和求二进制数中1的个数
- 求n个数的最大值和最小值
- 递归求n个数相加的和
- 求N个数的阶乘和
- 求特征数列(第n个数是第n-1个数和第n-2个数的和)的第X个数是多少
- 从N个数中取K个数出来,要求概率相等
- 求 1~n 之间素数的个数
- 一个数组中只有0和1,求0和1个数相等的最大连续子序列?
- 给个n,求1到n的所有数的约数个数的和~
- 给个n,求1到n的所有数的约数个数的和~
- 给一个奇数 N(1<N<2000),把从 1 到 N 2 的整数排成一个 N 行 N 列的方阵,使 该方阵的每一行、列和对角线上的 N 个数的和都相等
- 求(1~n)个数中1的个数
- C++语法基础--顺序容器(四)--赋值和swap
- ASC码对照表及java char之间的转换
- ZOJ 2334(Monkey King-左偏树第一题)
- yum安装varnish 后service启动失败之解决办法
- 看MySQL数据库大小
- 求n-1个数的和;量不定,概率相等;
- “守法”站长如何应对百度更新
- Eclipse设置java代码编辑区字体格式的方法
- acm新生赛第一场
- 15款非常有用的Adobe Flex教程
- oracle 视图
- 解决远古VOD注入漏洞
- 认识SpringMVC
- ActivityGroup(和TabHost一样的功能)