生活资讯
(随机算法)
2024-12-16 15:22  浏览:79

我希望本文有助于你了解测试软件是一件很重要也是一件不简单的事。

我们有一个程序,叫ShuffleArray(),是用来洗牌的,我见过N多千变万化的ShuffleArray(),但是似乎从来没人去想过怎么去测试这个算法。所以,我在面试中我经常会问应聘者如何测试ShuffleArray(),没想到这个问题居然难倒了很多有多年编程经验的人。对于这类的问题,其实,测试程序可能比算法更难写,代码更多。而这个问题正好可以加强一下我在《我们需要专职的QA吗?》中我所推崇的——开发人员更适合做测试的观点。

我们先来看几个算法(第一个用递归二分随机抽牌,第二个比较偷机取巧,第三个比较通俗易懂

递归二分随机抽牌

有一次是有一个朋友做了一个网页版的扑克游戏,他用到的算法就是想模拟平时我们玩牌时用手洗牌的方式,是用递归+二分法,我说这个程序恐怕不对吧。他觉得挺对的,说测试了没有问题。他的程序大致如下(原来的是用Javascript写的,我在这里凭记忆用C复现一下):

 

随便测试几次,还真像那么回事:

快排Hack法

让我们再看一个hack 快排的洗牌程序(只看算法,省去别的代码):

运行个几次,感觉得还像那么回事:

看不出有什么破绽。

大多数人的实现

下面这个算法是大多数人的实现,就是for循环一次,然后随机交换两个数

跑起来也还不错,洗得挺好的。

但是上述三个算法哪个的效果更好?好像都是对的。一般的QA或是程序员很有可能就这样把这个功能Pass了。但是事情并没有那么简单……

如何测试

在做测试之前,我们还需要了解一下一个基本知识——PC机上是做不出真随机数的,只能做出伪随机数。真随机数需要硬件支持。但是不是这样我们就无法测试了呢,不是的。我们依然可以测试。

我们知道,洗牌洗得好不好,主要是看是不是够随机。那么如何测试随机性呢?

试想,我们有个随机函数rand()返回1到10中的一个数,如果够随机的话,每个数返回的概率都应该是一样的,也就是说每个数都应该有10分之1的概率会被返回。

一到概率问题,我们只有一个方法来做测试,那就是用统计的方式。也就是说,你调用rand()函数100次,其中,每个数出现的次数大约都在10次左右。(注意:我用了左右,这说明概率并不是很准确的)不应该有一个数出现了15次以上,另一个在5次以下,要是这样的话,这个函数就是错的。

举一反三,测试洗牌程序也一样,需要通过概率的方式来做统计,是不是每张牌出现在第一个位置的次数都是差不多的。

于是,这样一来上面的程序就可以很容易做测试了。

下面是测试结果(测试样本1000次——列是每个位置出现的次数,行是各个字符的统计,出现概率应该是1/10,也就是100次):

递归随机抽牌的方法

很明显,这个洗牌程序太有问题。算法是错的!

快排Hack法

看看对角线(从左上到右下)上的数据,很离谱!所以,这个算法也是错的。

大多数人的算法

我们再来看看大多数人的算法。还是对角线上的数据有问题,所以,还是错的。

正确的算法

下面,我们来看看性能高且正确的算法—— Fisher_Yates算法

这个算法不难理解,看看测试效果(效果明显比前面的要好):

但是我们可以看到还是不完美。因为我们使用的rand()是伪随机数,不过已经很不错的。最大的误差在20%左右。

我们再来看看洗牌100万次的统计值,你会看到误差在6%以内了。这个对于伪随机数生成的程序已经很不错了。

如何写测试案例

测试程序其实很容易写了。就是,设置一个样本大小,做一下统计,然后计算一下误差值是否在可以容忍的范围内。比如:

  • 样本:100万次
  • 最大误差:10%以内
  • 平均误差:5%以内 (或者:90%以上的误差要小于5%)

注意

其实,以上的测试只是测试了牌在各个位置的概率。这个还不足够好。因为还可能会现在有Patten的情况。如:每次洗牌出来的都是一个循环顺序数组。这完全可以满足我上面的测试条件。但是那明显是错的。所以,还需要统计每种排列的出现的次数,看看是不是均匀。但是,如果这些排列又是以某种规律出现的呢?看来,这没完没了了。

测试的确是一个很重要,并不简单的事情。谢谢所有参与讨论的人。

附录

之前忘贴了一个模拟我们玩牌洗牌的算法,现补充如下:

我们来看看测试结果:(10万次)效果更好一些,误差在2%以内了。

(全文完)

    以上就是本篇文章【(随机算法)】的全部内容了,欢迎阅览 ! 文章地址:http://dgaty.xhstdz.com/xwnews/512.html 
     栏目首页      相关文章      动态      同类文章      热门文章      网站地图      返回首页 物流园资讯移动站 http://dgaty.xhstdz.com/mobile/ , 查看更多   
最新文章
SEO全攻略,解锁网站排名飞跃的黄金技巧
SEO优化技巧包括关键词研究、高质量内容创建、合理布局、外部链接建设等,全方位提升网站排名。关键词精准匹配、优化网站结构、
【原】2024最新股民电销获客渠道,运营商SDK/DPI实时捕捉电销股民数据手拨一手料子
随着互联网的不断发展和普及,作为运营商早已发现了大数据的重要性。运用大数据技术,可以深挖用户需求,运营商可以更加精准地获
【内存】Linux 页表、大页与透明大页|大页内存
目录页表与MMUCPU访问的是什么地址(虚拟地址,物理地址)?MMU如何工作MMU对内存的保护多级页表一、 内存映射与页表1. 内存映射2.
2024-2025学年高三级福建省福州市一检语文讲评课件.pptx
2024-2025年高三级福州一检语文讲评课件PARTONE现代文阅读(35分)(一)现代文阅读I(本题共5小题,19分)试题呈现:1.下列对原文相
百度关键词优化多少钱,关键词优化一个月多少钱
优化 one 关键词多少钱优化不管多好?郑州网站优化 one 关键词多少钱?Seo 关键词 优化如何收费很多企业会选择外包公司优化,那
成都SEO服务,助您企业网站搜索引擎排名飞跃
成都专业SEO服务,助力企业网站优化,提升搜索引擎排名,实现网站流量增长,助力企业品牌提升。全方位SEO策略,定制化服务,助您
11 个全球最好的 AI 文本转语音工具(2024 年)
人工智能技术在2024年继续在进步,除了大家所熟知的 ChatGPT 相关的大语言模型的出现,带动了一系列 AI应用的兴起,另外在语音人
烧饼修改器免root版本安卓 v20.0.6 官方正版
烧饼修改器是一款非常好用的加速器app,完美的解决了你的所有需求,超多软件功能让你的游戏变的更加的游戏,操作起来非常的简单
如何提升网站关键词的优化排名?
关键词是用户与网站的链接纽带,搜索引擎平台则可以诠释为一种媒介,用户通过搜索引擎搜索关键词到达网站页面则是“
揭秘空间SEO,网站排名提升的独家秘籍
深度解析空间SEO,揭秘提升网站空间排名的秘诀。通过优化空间配置、合理布局、关键词研究、外链建设等策略,实现网站在搜索引擎
相关文章