用rand随机函数怎么求指定范围的随机数?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用rand随机函数怎么求指定范围的随机数?相关的知识,希望对你有一定的参考价值。

参考技术A

在excel中可以使用randbetween函数。

RANDBETWEEN

返回位于指定的两个数之间的一个随机整数。每次计算工作表时都将返回一个新的随机整数。

语法

RANDBETWEEN(bottom,top)

Bottom  函数 RANDBETWEEN 将返回的最小整数。

Top  函数 RANDBETWEEN 将返回的最大整数。

示例 返回一组介于1到100间的随机数

参数seed是srand()的种子,用来初始化srand()的起始值。

但是,要注意的是所谓的“伪随机数”指的并不是假的随机数。其实绝对的随机数只是一种理想状态的随机数,计算机只能生成相对的随机数即伪随机数。计算机生 成的伪随机数既是随机的又是有规律的 —— 一部份遵守一定的规律,一部份则不遵守任何规律。比如“世上没有两片形状完全相同的树叶”,这体现到了事物的特性 —— 差异性;但是每种树的叶子都有近似的形状,这正是事物的共性 —— 规律性。从这个角度讲,我们就可以接受这样的事实了:计算机只能产生伪随机数而不是绝对的随机数。

系统在调用rand()之前都会自动调用srand(),如果用户在rand()之前曾调用过srand()给参数seed指定了一个值,那么 rand()就会将seed的值作为产生伪随机数的初始值;而如果用户在rand()前没有调用过srand(),那么系统默认将1作为伪随机数的初始 值。如果给了一个定值,那么每次rand()产生的随机数序列都是一样的~~

所以为了避免上述情况的发生我们通常用srand((unsigned)time(0))或者srand((unsigned)time(NULL))来 产生种子。如果仍然觉得时间间隔太小,可以在(unsigned)time(0)或者(unsigned)time(NULL)后面乘上某个合适的整数。

sql中的随机函数怎么用

sql server的rand()函数:返回0到1之间的随机浮点值
round()函数:返回数值表达式,舍入到指定长度或精度。
例如随机取得0~99之间的数: round(rand()*100,0)
随机取得100~199之间的数:round(rand()*100+100,0)
参考技术A Oracle:

DBMS_RANDOM.VALUE函数

1. 产生一个介于0和1之间(不包含0和1)的38位精度的随机数

SQL> SELECT DBMS_RANDOM.VALUE FROM dual;

VALUE
----------
.881021859

2. 产生一个介于指定范围之内的38位精度的随机数

SQL> SELECT DBMS_RANDOM.VALUE(1, 9999) FROM dual;

DBMS_RANDOM.VALUE(1,9999)
-------------------------
4261.38448

DB2

db2 => SELECT
db2 (cont.) => RAND()
db2 (cont.) => FROM SYSIBM.SYSDUMMY1;

1
------------------------
+3.71105075228126E-002

1 条记录已选择。

db2 =>
db2 => SELECT
db2 (cont.) => RAND()
db2 (cont.) => FROM SYSIBM.SYSDUMMY1;

1
------------------------
+1.65257728812525E-001

1 条记录已选择。

SQL Server

1> SELECT RAND()
2> go

------------------------
0.52387284052730643

(1 行受影响)
1> SELECT RAND()
2> go

------------------------
0.92388223999987373

(1 行受影响)本回答被提问者和网友采纳

以上是关于用rand随机函数怎么求指定范围的随机数?的主要内容,如果未能解决你的问题,请参考以下文章

EXCEL,怎么让随机数据rand函数的数据随机范围在单元格数字范围之内?

rand()随机函数产生的值的范围?

java随机数指定的范围怎么做

如何用rand函数产生一个随机数?

excel中RAND函数产生随机数的概率控制

c语言中rand()函数怎么用?