Anonymous user
Execute a Markov algorithm: Difference between revisions
Updated D entry
(Added OCaml solution) |
(Updated D entry) |
||
Line 1,383:
=={{header|D}}==
{{trans|Perl}}
<lang d>void main() {▼
import std.stdio, std.file, std.regex, std.string, std.range
std.functional;
const rules = "markov_rules.txt".readText.splitLines.split("");
▲void main() {
▲ auto re = ctRegex!(r"^([^#]*?)\s+->\s+(\.?)(.*)"); // 130 MB RAM.
foreach (test, const rule;
string[][] capt;
foreach (const line; rule) {
auto m = line.match(re);
if (!m.empty) {
//capt
capt ~= m.captures.dropOne.array;
}
}
REDO:
foreach (const c; capt) {
test = test.replace(c[0], c[2]);
if (c[1] == ".")
|