生活资讯
(随机算法)
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://changmeillh.xhstdz.com/xwnews/512.html 
     栏目首页      相关文章      动态      同类文章      热门文章      网站地图      返回首页 物流园资讯移动站 http://changmeillh.xhstdz.com/mobile/ , 查看更多   
最新文章
Bing网站管理员工具:完整分步教程
您可能已经知道Bing是第二大搜索引擎,对吗?所以你肯定已经设置了必应网站管理员工具。或者也许你还没有,因为你从来没有真正考
百度外链收录工具,助你网站排名飙升
在此次交流中,我将聚焦于对百度外链收录查询工具的实践经验分享。身为网站运营者,皆知外链之重要性——其既关乎网站排名与流量
实测ChatGPT插件真香用法,视频一键变脑图,高数作业轻松拿捏
原创 关注前沿科技 量子位梦晨 丰色 发自 凹非寺量子位 | 公众号 QbitAISam Altman诚不我欺:像用iPhone一样使用ChatGPT,就是现
chatGPT中文免费版app功能
chatGPT中文免费版app,推荐给大家,是一款可以让我们免费在线使用ai智能机器人进行聊天互动以及交友的神奇工具。它通过后台代码
昆明网站制作工作室:打造完美网站的全面指南313
在当今竞争激烈的数字时代,拥有一个精心制作的网站对企业的成功至关重要。对于位于昆明的企业来说,选择一个经验丰富的网站制作
电商图像处理新利器!AI一键更换商品背景的解决方案
当你在电商平台上看到那些令人眼前一亮的商品图时,是否曾经想过它们是如何制作的?尤其是在产品图片背景处理上,想必许多电商运
全网ai工具导航合集网站推荐,SEO+AIGC必备!【干货收藏】
​​这篇文章是白杨SEO好友兼前前同事大鱼论AI用心整理的,他也在我的玩赚流量星球和群里。整理得很全,我想你可能会用到,所以
6.如何利用SEO赚取美金
众所周知,SEO(Search Engine Optimization)搜索引擎优化,是一种获取流量的方式,利用搜索引擎规则提高网站在相关搜索内的自
欧陆国际:外贸SEO应该怎么做
外贸SEO应该怎么做?外贸行业有两种线上模式:自己搭建网站、借助于B2B平台开网店,自建网站不受平台限制,推广方式也比较自由,
各个网站及搜索引擎收录地址大全
搜索引擎网站收录地址大全 【点此提交您的搜索引擎】360搜索引擎登录入口:http://info.so.360.cn/site_submit.html即刻
相关文章