我正在尝试为我的Ebay业务制作一个长度为15位数字的C ++程序,但是我希望前5位数字相同。
例如ex:152328476529876 PIN:1000 152323123642345 PIN:9433 152321254213432 PIN:3222
我尝试制作一个随机数生成器,但无法到达前5位相同,但后10位相同的位置。用随机针。
#include <iostream>
#include <cstdlib>
const int maximum_number = 9999999999;
const int minimum_number = 1;
unsigned int i;
const int maximum_pin = 999;
const int minimum_pin = 0;
unsigned int pin;
int main()
{
// Print 100 random numbers
for (int count = 0; count <= 1000; ++count)
{
const int new_number = (rand() % (maximum_number - minimum_number)) + maximum_number;
const int new_pin = (rand() % (maximum_pin - minimum_pin)) + maximum_pin;
std::cout << "15232" << new_number << " Pin : "<< new_pin << "\n";
}
return 0;
152321410094708 Pin : 1384
152321410073128 Pin : 1567 etc
我遇到的问题是前5个数字是相同的,这是我想要的方式,但是14100仍然是相同的,因此也应该随机分配,而不仅仅是后5个数字... >
另外,引脚仅停留在1000,它们从未超过1999等。
答案 0 :(得分:1)
您应该使用C ++ 11中的rand()
标头,而不是使用<random>
和取模运算。使用n3847中的Walter E. Brown的功能工具包,您可以使用:
#include <cstdint>
#include <iostream>
#include <iomanip>
#include <random>
const uint64_t maximum_number = 9999999999;
const uint64_t minimum_number = 1;
const uint64_t maximum_pin = 9999;
const uint64_t minimum_pin = 0;
const uint64_t prefix = 15232;
auto& global_urbg() {
static std::default_random_engine u{};
return u;
}
void randomize() {
static std::random_device rd{};
global_urbg().seed(rd());
}
uint64_t pick_a_number(uint64_t from, uint64_t thru) {
static std::uniform_int_distribution<uint64_t> d{};
using parm_t = decltype(d)::param_type;
return d(global_urbg(), parm_t{from, thru});
}
int main() {
randomize();
for (int count = 0; count < 100; ++count) {
const uint64_t new_number = pick_a_number(minimum_number, maximum_number);
const uint64_t new_pin = pick_a_number(minimum_pin, maximum_pin);
std::cout << prefix << std::setw(10) << std::setfill('0') << new_number
<< " Pin : " << std::setw(4) << std::setfill('0') << new_pin << "\n";
}
return 0;
}
示例输出:
152325021252553 Pin : 1766
152327824160815 Pin : 7717
152321697896629 Pin : 3659
152320879192254 Pin : 8832
152325057425972 Pin : 2831
152323353939394 Pin : 1681
152324684928448 Pin : 9800
152328117866049 Pin : 4173
152326884989008 Pin : 4663
152320007759205 Pin : 7264
152327718061191 Pin : 3968
152322605655403 Pin : 8213
152324442390907 Pin : 7916
152322386351545 Pin : 4683
152321687805442 Pin : 3886
152328171047426 Pin : 6344
152327001747780 Pin : 2636
152325373164268 Pin : 3676
答案 1 :(得分:0)
您的问题是,使用rand()生成随机数会为您提供一个介于0到至少32767之间的数字(取决于您的平台,请参见here),并且这个数字不够大。另一个问题是数据类型int
没有足够的位来存储这么大的数字。
这完全取决于平台,但是这些是最小尺寸:
int
使用至少16位,可以存储0到65536(如果是无符号)的数字long
使用至少32位,可以存储0到4294967296之间的数字(无符号)long long
使用至少64位,可以存储0到18446744073709551616(如果未签名)之间的数字因此,您的最大值已经存在问题,因为它们不适合int。如果您想确定自己的数字有多大,可以使用stdint.h
并用ints
,uint64
等指定int32
。
您想要的是10个随机数字。这可以通过以下方式实现:
for (int count = 0; count < 1000; count++) {
// leading number must not be 0
long long randomNumber = (rand() % 9) + 1;
for (int i = 0; i<9; i++) {
randomNumber *= 10;
randomNumber += rand() % 10;
}
std::cout << "15232" << new_number << "\n";
}
我认为大头针有类似的问题