c++ 产生不同随机数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了c++ 产生不同随机数相关的知识,希望对你有一定的参考价值。

用c++如何产生不同的随机数?
#include<iostream>
#include<ctime>
#include<cmath>

int main()

int i,j;
for(i=0;i<10;i++)

for(j=0;j<10;j++)


srand((unsigned)time( NULL ) );

printf("%d ",rand());

printf("\n");


return 0;


用上述程序产生的是100个随机数是相同的,原因是它们几乎是在同一秒内完成的,因此时间种子是相同的,产生的随机数就相同。
如何改进,让这一百个随机数不同呢?
不要用Sleep,这样太浪费时间。
2l说的很对,能不能给我讲讲为什么放在外面就可以了。

一. 不指定范围产生随机数

     用到函数rand(),函数原型为int rand(),无参数。此时会产生一个介于0~RAND_MAX间的整数。RAND_MAX的大小可以查看,在include文件夹(linux在usr目录、windows在安装目录)的stdlib.h可以看到,linux下其值为2147483647(),其值与具体系统有关。

范例:

二. 指定范围产生随机数,产生0到某个数的随机数

没有现成的函数,但是可以通过取余得到

范例:

注意:以上两个程序每次执行产生的结果是相同的,既是个伪随机数。rand()产生随机数与具体的种子有关,当不特意用srand()获取种子时,种子的默认值为1,因此需要用srand()函数产生不同的种子,srand函数原型:void srand(unsigned seed);为了产生不同的种子值,通常用时间作为参数值。

三. 指定范围产生随机数

要求:指定范围(m,n),m、n关系不定,随机数包括m和n

想方设法,把范围(m,n)改变到(0,X),到最后再转移回去。三种情况

范例:

参考技术A 你可以把srand((unsigned)time(NULL));这个种子设置函数放到循环外面啊! 参考技术B srand((unsigned)time( NULL ) );
修改为
Sleep(2);//这样不浪费时间的.100个随机数用200毫秒,够小的了.
srand((int)(time(0)-getpid()));
=====
我认为更好的一种方法.可以利用GUID来生成.
//--生成GUID的代码
//--相关程序/微软guidgen.exe

#include "stdafx.h"
#include <objbase.h>
#include <stdio.h>

//--生成GUID
const char* newGUID()

static char buf[64] = 0;
GUID guid;
if (S_OK == ::CoCreateGuid(&guid))

_snprintf(buf, sizeof(buf)
, "%08X-%04X-%04x-%02X%02X-%02X%02X%02X%02X%02X%02X"
, guid.Data1
, guid.Data2
, guid.Data3
, guid.Data4[0], guid.Data4[1]
, guid.Data4[2], guid.Data4[3], guid.Data4[4], guid.Data4[5]
, guid.Data4[6], guid.Data4[7]
);

return (const char*)buf;


int main(int argc, char* argv[])

//--COM
CoInitialize(NULL);

printf(newGUID());
printf("\r\n");

//--COM
CoUninitialize();

return 0;
参考技术C 原因很简单,要产生不同的数,并不需要每一次调用rand()前都进行srand改变种子,事实上种子只需要在程序开始之初初始化一次就足够了,后面的rand会随即取数。
相反的,如果象你这样把srand放到循环体里面,就等于每一次rand前的种子都进行了一次初始化,而且循环的时间非常短,time获取到的种子全部相同,故而产生的数字都是一样的。time(0)返回的是系统的时间(从1970.1.1午夜算起),单位:秒,而那个循环运行起来耗时连0.000001秒都不到! 也就是说,srand(time(0)) 连着20次的种子是一样的,种子一样,生产的随机数当然是一样了。本回答被提问者采纳
参考技术D srand((unsigned)time( NULL )*j );

SQLSever: 怎样在select中的每一行产生不同的随机数?

select 的随机函数有点假, 或许是由于它是基于时间来的吧, 同一select中由于时间无法错开导致产生的随机数都是一样的。 怎样做到让不同的行拥有不同的随机数呢?

以下以产生某个月的随机日期来演示样例吧。

--创建最小为1 最大为31 的视图
if object_id(‘view_rand_int31‘) is not null
begin
	drop view view_rand_int31
end
go
create view view_rand_int31
as 
	select cast(ceiling(rand() * 31) as int) as [r]
go
--创建日期(天)的随机函数
if object_id(‘dbo.Fun_GetRandDay‘) is not null
begin
	drop function dbo.Fun_GetRandDay
end
go
CREATE FUNCTION dbo.Fun_GetRandDay
(
@max INT
)
returns int
as 
begin
	declare @r int
	select @r = [r] from view_rand_int31
	
	while @r>@max
	begin
		select @r = [r] from view_rand_int31
		if @r<[email protected]
		begin
			break;
		end
	end
	return @r
end
go
--试验select条件下实现多条记录同一时候取随机数
--插入试验数据行
declare @t table(rowNum int identity, [yearMonth] nvarchar(20))
declare @i int,@imax int
select @i=1,@imax =28
while @i<[email protected]
begin
	insert into @t ([yearMonth]) select ‘2014年2月‘
	set @[email protected]+1
end
--运行查询
select *,  
	cast( ‘2014-02-‘ + cast( dbo.Fun_GetRandDay(28) as varchar(2)) as datetime) as [date], 
	(select cast(ceiling(rand() * 28) as int)) as [r]  
from @t






以上是关于c++ 产生不同随机数的主要内容,如果未能解决你的问题,请参考以下文章

在c++中如何使每次输出的随机数不同?

C++产生随机数

C++产生随机数

c++中如何产生随机字符串

c++ rand随机数生成(随机种子设置)

C++产生随机数的