//产生区间0-2^32区间上的随机数
unsigned int my_rand32(unsigned int M, unsigned int N)
{
return (unsigned int)((double)rand()/(double)RAND_MAX*(N-M+1)+M);
}
//产生区间0-2^64区间上的随机数
unsigned __int64 my_rand64(unsigned __int64 M, unsigned __int64 N)
{
return (unsigned __int64)((double)rand()/(double)RAND_MAX*(N-M+1)+M);
}
上述[M, N]意思是,和数学表达方式一样,即落在的区间包含着M, 包含着N。
上述的__int64是VC、VS20XX的表达,若在Linux环境下,换成long long类型。
测试:
for (int i=0; i<10; i++)
{
unsigned int r0 = my_rand0(0, 0xFFFFFFFF-1);
printf("1. =%ld, %x\r\n", r0, r0);
unsigned __int64 r1 = my_rand1(0, 0xFFFFFFFFFFFFFF0);
printf("2. =%I64d, %I64x\r\n", r1, r1);
}
本文介绍了如何使用C/C++在指定范围内生成32位和64位的随机数,并提供了具体的实现代码。此外还展示了如何通过示例程序验证随机数生成的有效性。
436

被折叠的 条评论
为什么被折叠?



