Cocos2dx 3.0 过渡篇(五) 随机数的获取
本来上午是要转载一篇看起来还不错的博客,被cocos2dx官方微博推荐过。谁知道早上打开链接时那篇博客已经转为私密了。早知道昨晚就应该复制一下内容,今天厚脸皮的来篇原创岂不妙哉。哈哈。
1、简单的随机数用法:CCRANDOM_0_1示例如下:
2、上述的方法虽然简便,但是运行多次后,发现产生的随机数都一样的,这是为什么呢?这就涉及到“随机数种子”这东西了。 什么叫随机数种子?这里我们不妨.......百度一下。 在计算机中并没有一个真正的随机数发生器,但是可以做到使产生的数字重复率很低,这样看起来好象是真正的,实现这一功能的程序叫伪随机数发生器。 好了,看完上述介绍,多少对随机数种子有了一定的概念,接下来就讲下该如何在调用随机数时初始化随机数种子。代码如下:
别问我为什么是这样写,就跟“不要问我从哪里来”一样的道理。使用起来如下:
恩,看完后不知道你会不会有种疑问,为什么不再每一次for循环都初始化下随机数种子,这样子不就更随机了吗?如:
运行后会发现产生的数又不随机了。原来初始化随机数种子一定要在循环外,在循环内就没什么效果了。如果你要问我为什么是这样的,我只能说“不要问我从....”。 呵呵,开玩笑的,我姑且给个自己瞎猜想的结论吧: 随机数种子就相当于随机数的重置开关,你如果想获得随机数,肯定要先把开关打开吧,初始化了随机数种子,也就是相当于打开开关,这时候“种子”就开始起来了,你每隔一段时间获取随机数,它都会反馈给你一个不同的位置数据,而如果你每获取数据就要初始化随机数种子(也就是重启开关),这就相当于“种子”又从起点重新出发,这不是要累死“种子”的节奏么? 哈哈,都是瞎掰的,大家看看就好啦。 3、接下来讲下如何在一定范围内,产生K数量不同的随机数。 在网上能找到几种实现方法,我这里只记录下认为比较高效的做法 用数组A[]存放x到y的数值,然后在(x,y)产生第一个随机数H做为下标,从数组A中取出A[H],然后将数组最后个元素赋值给A[H],再重新在(x,y-1)产生,如些循环 具体代码实现
恩,就写这些咯。哈 转发请务必注明出处:http://blog.csdn.net/start530/article/details/18713217 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- Postgresql与innoDB的多版本并发控制技术比较
- 从PostgreSQL中的数字获取月份名称
- react+webpack开发环境搭建
- Ruby的排序方法如何与组合比较(太空船)运算符一起使用?
- 正则化解决过拟合问题
- xcode – AppCode – UI Designer插件
- c# – CA2000:Microsoft.Reliability:在对所有引用超出范
- ruby-on-rails – 在Ruby on Rails中,渲染’shared / score
- 自定义View编译失败。Binary XML file line #255: Error in
- ruby-on-rails – Rails将文件上传到ftp服务器