diff options
author | Star Rauchenberger <fefferburbia@gmail.com> | 2024-11-04 02:19:09 -0500 |
---|---|---|
committer | Star Rauchenberger <fefferburbia@gmail.com> | 2024-11-04 02:19:09 -0500 |
commit | 76bc3b3677062c0c1a6b9fa08ff20d12e470159c (patch) | |
tree | 390897784acdec4f002df4a13e5d63f1f641fb40 /designer.cpp | |
parent | 5a65625cb589b2cb5b336e1fa5748df8dcdb8f6a (diff) | |
download | wizard-76bc3b3677062c0c1a6b9fa08ff20d12e470159c.tar.gz wizard-76bc3b3677062c0c1a6b9fa08ff20d12e470159c.tar.bz2 wizard-76bc3b3677062c0c1a6b9fa08ff20d12e470159c.zip |
Some old refactoring + some new refactoring
Diffstat (limited to 'designer.cpp')
-rw-r--r-- | designer.cpp | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/designer.cpp b/designer.cpp new file mode 100644 index 0000000..024796f --- /dev/null +++ b/designer.cpp | |||
@@ -0,0 +1,69 @@ | |||
1 | #include "designer.h" | ||
2 | |||
3 | std::list<usage> designer::generate(std::mt19937& rng) const { | ||
4 | std::list<usage> result; | ||
5 | size_t cur = 0; | ||
6 | |||
7 | while (cur < text_.length()) { | ||
8 | const solution& curSol = get(cur); | ||
9 | const std::vector<size_t>& posLens = curSol.lengths; | ||
10 | |||
11 | std::uniform_int_distribution<size_t> lenDist(0, posLens.size() - 1); | ||
12 | size_t len = posLens.at(lenDist(rng)); | ||
13 | |||
14 | const ps_type& prefix = curSol.prefix; | ||
15 | std::uniform_int_distribution<size_t> cardDist(0, prefix.getCount() - 1); | ||
16 | size_t cardIndex = cardDist(rng); | ||
17 | std::tuple<size_t, size_t> pd = prefix.at(cardIndex); | ||
18 | |||
19 | result.emplace_back(std::get<0>(pd), std::get<1>(pd), len); | ||
20 | |||
21 | cur += len; | ||
22 | } | ||
23 | |||
24 | return result; | ||
25 | } | ||
26 | |||
27 | solution designer::calculate(size_t i) const { | ||
28 | if (i == text_.length()) { | ||
29 | return {titles_, {}, 0}; | ||
30 | } | ||
31 | |||
32 | const ps_type& prefix = titles_.find(text_, i); | ||
33 | |||
34 | bool foundScore = false; | ||
35 | size_t bestScore; | ||
36 | std::vector<size_t> bestLens; | ||
37 | |||
38 | for (int j = 1; (j <= prefix.getDepth()) && (i + j <= text_.length()); j++) { | ||
39 | const solution& subSol = get(i + j); | ||
40 | |||
41 | if (subSol.score > 0 || (i + j == text_.length())) { | ||
42 | size_t tempScore = subSol.score + 1; | ||
43 | |||
44 | if (!foundScore || tempScore < bestScore) { | ||
45 | foundScore = true; | ||
46 | bestScore = tempScore; | ||
47 | |||
48 | bestLens.clear(); | ||
49 | bestLens.push_back(j); | ||
50 | } else if (tempScore == bestScore) { | ||
51 | bestLens.push_back(j); | ||
52 | } | ||
53 | } | ||
54 | } | ||
55 | |||
56 | if (!foundScore) { | ||
57 | return {titles_, {}, 0}; | ||
58 | } else { | ||
59 | return {prefix, std::move(bestLens), bestScore}; | ||
60 | } | ||
61 | } | ||
62 | |||
63 | const solution& designer::get(size_t i) const { | ||
64 | if (!solutions_.at(i)) { | ||
65 | solutions_[i] = std::make_unique<solution>(calculate(i)); | ||
66 | } | ||
67 | |||
68 | return *solutions_.at(i); | ||
69 | } | ||