随机函数与随机抽查.doc_第1页
随机函数与随机抽查.doc_第2页
随机函数与随机抽查.doc_第3页
随机函数与随机抽查.doc_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

随机函数与随机抽查随机函数就是随机产生数的函数,是EXCEL中很重要的函数。比较简单,格式为“=rand()”,无参数,其结果是生成0-1之间的随机数。 一、几种常见用法: 1、生成随机数字 (1)生成0-1之间的随机数字这是最基本的用法,但比较简单,在任意单元格输入“=rand()”,即可生成0-1之间的随机数。(2) 生成0-9之间的随机整数这要与取整函数联合应用。在任意单元格输入“=int(rand()*10)”, 即可生成0至9的整数,以此类推; (3)生成a与b之间的随机实数还是与取整函数联合应用。在任意单元格输入“=rand()*(b-a)+a”, 即可生成生成a与b之间的随机实数。(4)生成a与b之间的随机整数还是与取整函数联合应用。在任意单元格输入”“=int(rand()*(b-a)+a”即可。(5) 生成固定位数的随机整数以三位整数为例,其余类推。在任意单元格输入“=int(rand()*1000)”即可。注意:如果要使用函数rand()生成一随机数,并且使之不随单元格计算而改变,可以在编辑栏中输入“=rand()”,保持编辑状态,然后按F9,将公式永久性地改为固定数字。不过,这样只能一个一个的永久性更改,如果数字比较多,也可以全部选择之后,另外选择一个合适的位置粘贴,粘贴的方法是点击右键,选择“选择性粘贴”,然后选择“数值”,即可将之前复制的随机数公式产生的数值(而不是公式)复制下来!2、产生随机字母 随机小写字母:“=CHAR(INT(RAND()*26)+97)”随机大写字母:“=CHAR(INT(RAND()*26)+65)”随机大小写混合字母:“=CHAR(INT(RAND()*26)+if(INT(RAND()*2)=0,65,97)” 3、产生随机的六位数的字母和数字混合=CONCATENATE(IF(INT(RAND()*2)=0,CHAR(INT(RAND()*9+48),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*25+65),CHAR(INT(RAND()*25+97),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*9+48),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*25+65),CHAR(INT(RAND()*25+97),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*9+48),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*25+65),CHAR(INT(RAND()*25+97),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*9+48),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*25+65),CHAR(INT(RAND()*25+97),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*9+48),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*25+65),CHAR(INT(RAND()*25+97),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*9+48),IF(INT(RAND()*2)=0,CHAR(INT(RAND()*25+65),CHAR(INT(RAND()*25+97) 4、随机不重复数字序列的生成方法一有些情形下,我们需要生成一个不重复的随机序列。比如:我们要模拟洗牌,将一副扑克牌去掉大小怪后剩下的52张打乱。比较笨的方法是在1-52间每生成一个随机数后,检查该随机数是否出现过,如果是第一次出现,就放到序列里,否则重新生成一个随机数作检查。在 excel worksheet里面用这种办法,会造成if多层嵌套,不胜其烦,在VBA里面做简单一些,但是效率太差,越到序列的后端,效率越差。当然也有比较好的办法,在VBA里面,将a(1)-a(52)分别赋予1-52,然后做52次循环,例如,第s次生成一个1-52间的随机数r,将a(s)与a(r)互换,这样的话,就打乱了原有序列,得到一个不重复的随机序列。VBA里这个算法是很容易实现的,但是,出于通用性和安全考虑,有的时候我们并不希望用VBA。我们来看看在worksheet里面如何利用内置函数实现这个功能。 (1)在A1-A52间填入=INT(RAND()*52)+1,产生1-52间的随机数,注意这里是有重复的。(2)在B1-B52间填入1-52 (3)在C54-BB54填入1-52 (4)在C1填入=IF(ROW()=C$54,INDEX(B$1:B$52,INDEX($A$1:$A$52,C$54),IF(ROW()=INDEX($A$1:$A$52,C$54),INDEX(B$1:B$52,C$54),B1)。二、随机抽查随机函数的应用很广,比如可以用来做随机抽查。举一个我在“百度知道”回答问题时遇到的例子。有126个公式生成的数据,我现在需要随机从这126个数值中抽取5个连续10次。我是这样回答的:假设126个数据放在A1-

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论