【发布时间】:2018-06-25 17:01:46
【问题描述】:
我需要在 C++ 中创建算法实现以生成随机数到 f.e 表而不重复和列表。
我创建了类似的代码,但是当我将 n=32769 放入控制台程序停止工作时,它就停止工作了。当我将数字放在 0-32768 范围内时,它就可以工作。知道这段代码有什么问题吗? 编译时我没有错误/警告。
#include <stdio.h>
#include <iostream>
#include <ctime>
int main()
{
clock_t start = clock();
int n;
std::cout << "n:";
std::cin >> n;
bool *used_numbers = new bool[n];
memset(used_numbers, false, sizeof(used_numbers[0]) * n);
int *permutation = new int[n];
srand(unsigned(std::time(NULL)));
int rnd_number;
for (int i = 0; i < n; i++)
{
rnd_number = rand() % n;
if (!used_numbers[rnd_number])
{
permutation[i] = rnd_number;
used_numbers[rnd_number] = true;
}
else
i--;
}
std::cout << "Permutation: \n ";
for (int k = 0; k < n; k++)
{
std::cout << permutation[k] << " ";
}
std::cout << std::endl;
printf("[Debug]: %lu ms\n", clock() - start);
getchar();
system("pause");
return 0;
}
【问题讨论】:
-
停止工作是什么意思?它会崩溃吗?它输出错误的东西吗?是不是无限循环?
-
"编译时我没有错误/警告。" 如果程序编译,并不意味着它可以正常工作。
-
打印时您机器上的
RAND_MAX的值是多少? -
我猜你正在使用的
rand()的实现会生成[0 .. 32767] 范围内的值,这并不罕见。生成 32768 个值将不可避免地创建至少一个副本。检查RAND_MAX的值。 -
这不是直接的问题,但是这个算法还有很多不足之处。使用
std::shuffle。或者,如果您想了解理论,请阅读Fisher-Yates shuffle。
标签: c++ arrays algorithm random permutation