- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我的作业涉及生成 0
和 2^30
之间的随机整数。现在,在过去我们了解到 rand()
只返回小于 RAND_MAX
的整数,这小于 UINT_MAX
,并且我们可以使用位移来填充 UINT_MAX
容量。从我所做的一些阅读中(这里,关于 SO),我意识到如果这些数字的分布对我很重要,这可能不是一个好主意。话虽如此,我的教授已经指定了这种方法。
我的问题是,位移多少? RAND_MAX
和 UINT_MAX
之间的差异是否始终存在一个安全常数来进行位移?或者是否需要进行一些初始探测以确定要移位的数字?我是否应该保持位移一点点并检查 UINT_MAX
?
我问的原因是,UINT_MAX
被定义为至少是某个数字 (65535
),但在我的机器上 UINT_MAX
更大(4294967295
)。这让我担心我可能会在周末完成作业,到达学校后发现一切都不够顺利,无法提交。
谢谢!
引用资料:
我读过几个类似的问题,但无法从他们那里得到答案。
Is the value of RAND_MAX
always (2^n)-1
?
generating a random number within range 0
to n
where n
can be > RAND_MAX
实际上,上面的第二个问题让我怀疑这样做是否值得?
最佳答案
您的问题围绕着是否 RAND_MAX
和 UINT_MAX
他们之间有一点转变。这减少了是否 UINT_MAX
的问题和 RAND_MAX
形式为 2^k - 1
. UINT_MAX
几乎肯定会出现在任何基于二进制数系统的计算机上。如果sizeof(int)=32
然后位 k=32
, 如果 sizeof(int)=64 bit
然后 k=64
等。现在我们可以考虑RAND_MAX
.在大多数实现中,答案是 RAND_MAX
几乎总是采用 2^k - 1
的形式.为什么?我们需要考虑 rand()
的大多数实现方式实际工作。
rand()
通常使用线性同余生成器(参见 http://en.wikipedia.org/wiki/Linear_congruential_generator 或 Knuth“计算机程序员的艺术第 2 部分:半数值算法”)。基本上,随机数是一个带有 seed
的序列。
x(k+1) = ( a x(k) + c ) % m
(即 C 库存储最后一次迭代的 x(k)
并且当您调用 rand()
时它返回 x(k+1)
)
要获得良好的质量,必须谨慎选择生成器的参数(a
、c
和 m
)。质量通常涉及序列重复自身之前的次数等。选择这些参数的一个紧张因素是使m
成为可能。接近UINT_MAX
尽可能避免浪费潜在的随机位。如果你研究发电机,通常正确的选择是 m
略小于 UINT_MAX
.您还需要制作 m
一个素数。
通常您需要 rand()
尽可能快,所以你希望这些操作便宜。最便宜mod
计算是一种形式 foo % (2^k - 1)
因为它可以实现为 foo & (1<<k-1)
.专供选择k
你会得到一个梅森素数。
例如,一个常见的选择是 k=31
产生素数 2^31-1 = 2147483647
.这是 32 位整数的典型选择,其中 UINT_MAX=2^32-1 = 4294967295
.对于 64 位数字,一个有 UINT_MAX=2^64-1=18446744073709551615
RAND_MAX 的选择是 2^61-1 = 2305843009213693951
.
总而言之,回答你的问题:在大多数实现中,你可以假设有一个简单的位移位,但是,没有真正的保证。至少你应该在你的程序初始化时做一个运行时测试。如果您使用 C++,更好的做法是使用 static_assert
在编译时检测您的假设是否正确,如果不正确则无法编译。 Boost 有这样一个静态断言,最近批准的标准 C++11 也是如此……即可以做到(尽管编写 is_power_of_two_minus_one
的静态版本可能需要一些工作):
unsigned int myrand()
{
static_assert(sizeof(int)==4,"sizeof(unsigned int) != 4");
static_assert(is_power_of_two_minus_one(RAND_MAX),"RAND_MAX not a power of two minus one");
static_assert(is_power_of_two_minus_one(UINT_MAX),"UINT_MAX not power of two minus one");
unsigned int raw_rand=rand();
// do your bit shift to adjust raw_rand
return raw_rand;
}
关于c++ - RAND_MAX 和 UINT_MAX 之间的差异会有所不同吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8283570/
#include using namespace std; class C{ private: int value; public: C(){ value = 0;
这个问题已经有答案了: What is the difference between char a[] = ?string?; and char *p = ?string?;? (8 个回答) 已关闭
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 7 年前。 此帖子已于 8 个月
除了调试之外,是否有任何针对 c、c++ 或 c# 的测试工具,其工作原理类似于将独立函数复制粘贴到某个文本框,然后在其他文本框中输入参数? 最佳答案 也许您会考虑单元测试。我推荐你谷歌测试和谷歌模拟
我想在第二台显示器中移动一个窗口 (HWND)。问题是我尝试了很多方法,例如将分辨率加倍或输入负值,但它永远无法将窗口放在我的第二台显示器上。 关于如何在 C/C++/c# 中执行此操作的任何线索 最
我正在寻找 C/C++/C## 中不同类型 DES 的现有实现。我的运行平台是Windows XP/Vista/7。 我正在尝试编写一个 C# 程序,它将使用 DES 算法进行加密和解密。我需要一些实
很难说出这里要问什么。这个问题模棱两可、含糊不清、不完整、过于宽泛或夸夸其谈,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开,visit the help center . 关闭 1
有没有办法强制将另一个 窗口置于顶部? 不是应用程序的窗口,而是另一个已经在系统上运行的窗口。 (Windows, C/C++/C#) 最佳答案 SetWindowPos(that_window_ha
假设您可以在 C/C++ 或 Csharp 之间做出选择,并且您打算在 Windows 和 Linux 服务器上运行同一服务器的多个实例,那么构建套接字服务器应用程序的最明智选择是什么? 最佳答案 如
你们能告诉我它们之间的区别吗? 顺便问一下,有什么叫C++库或C库的吗? 最佳答案 C++ 标准库 和 C 标准库 是 C++ 和 C 标准定义的库,提供给 C++ 和 C 程序使用。那是那些词的共同
下面的测试代码,我将输出信息放在注释中。我使用的是 gcc 4.8.5 和 Centos 7.2。 #include #include class C { public:
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我的客户将使用名为 annoucement 的结构/类与客户通信。我想我会用 C++ 编写服务器。会有很多不同的类继承annoucement。我的问题是通过网络将这些类发送给客户端 我想也许我应该使用
我在 C# 中有以下函数: public Matrix ConcatDescriptors(IList> descriptors) { int cols = descriptors[0].Co
我有一个项目要编写一个函数来对某些数据执行某些操作。我可以用 C/C++ 编写代码,但我不想与雇主共享该函数的代码。相反,我只想让他有权在他自己的代码中调用该函数。是否可以?我想到了这两种方法 - 在
我使用的是编写糟糕的第 3 方 (C/C++) Api。我从托管代码(C++/CLI)中使用它。有时会出现“访问冲突错误”。这使整个应用程序崩溃。我知道我无法处理这些错误[如果指针访问非法内存位置等,
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 7 年前。
已关闭。此问题不符合Stack Overflow guidelines 。目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,因为
我有一些 C 代码,将使用 P/Invoke 从 C# 调用。我正在尝试为这个 C 函数定义一个 C# 等效项。 SomeData* DoSomething(); struct SomeData {
这个问题已经有答案了: Why are these constructs using pre and post-increment undefined behavior? (14 个回答) 已关闭 6
我是一名优秀的程序员,十分优秀!