-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathnamegenerator.cpp
36 lines (33 loc) · 1.33 KB
/
namegenerator.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
//
// Created by nbollom on 12/11/18.
//
#include "namegenerator.hpp"
#include <vector>
using namespace std;
std::string GenerateRandomName(const std::shared_ptr<std::mt19937_64>& engine) {
static vector<string> parts1 = {"br", "cr", "dr", "fr", "gr", "j", "kr", "l", "m", "n", "pr", "r", "sh", "tr", "v", "wh", "x", "y", "z"};
static vector<string> parts2 = {"a", "a", "e", "e", "i", "i", "o", "o", "u", "u", "ae", "ie", "oo", "ou"};
static vector<string> parts3 = {"b", "ck", "d", "g", "k", "m", "n", "p", "t", "v", "x", "z"};
static uniform_int_distribution<unsigned long> distribution1(0, parts1.size() - 1);
static uniform_int_distribution<unsigned long> distribution2(0, parts2.size() - 1);
static uniform_int_distribution<unsigned long> distribution3(0, parts3.size() - 1);
string result;
for (int i = 0; i < 6; ++i) {
string part;
switch (i % 3) {
case 0:
part = parts1[distribution1(*engine)];
break;
case 1:
part = parts2[distribution2(*engine)];
break;
case 2:
part = parts3[distribution3(*engine)];
break;
default:break;
}
result.append(part);
}
result[0] = static_cast<char>(static_cast<int>(result[0]) - 32);
return result;
}