Dinesman's multiple-dwelling problem: Difference between revisions

Line 1,336:
 
===Simpler Version===
<syntaxhighlight lang="d">void main() {
void main() {
import std.stdio, std.math, std.algorithm, permutations2:permutations;
 
["Baker", "Cooper", "Fletcher", "Miller", "Smith"]
.permutations
.filter!(s =>
s.countUntil("Baker") != 4 && s.countUntil("Cooper") != 0 &&
s.countUntil("Fletcher") != 0 && s.countUntil("Fletcher") != 4 &&
s.countUntil("Miller") > s.countUntil("Cooper") &&
abs(s.countUntil("Smith") - s.countUntil("Fletcher")) != 1 &&
abs(s.countUntil("Cooper") - s.countUntil("Fletcher")) != 1)
.writeln;
}</syntaxhighlight>
 
The output is the same.
 
121

edits