Permutations by swapping: Difference between revisions
→{{header|F_Sharp|F#}}: Nicer interface
SqrtNegInf (talk | contribs) m (→Alternative Iterative version: Fix comment: Perl 6 --> Raku) |
(→{{header|F_Sharp|F#}}: Nicer interface) |
||
Line 914:
let ni = [|for n in N -> 0|]
let gel = Array.length(N)-1
yield
let rec _Ni g e l = seq{
match (l,g) with
|_ when l<0 -> gn.[g] <- -gn.[g]; yield! _Ni (g-1) e (ni.[g-1] + gn.[g-1])
|(1,0) ->
|_ when l=g+1 -> gn.[g] <- -gn.[g]; yield! _Ni (g-1) (e+1) (ni.[g-1] + gn.[g-1])
|_ -> let n = N.[g-ni.[g]+e];
N.[g-ni.[g]+e] <- N.[g-l+e]; N.[g-l+e] <- n; yield
ni.[g] <- l; yield! _Ni gel 0 (ni.[gel] + gn.[gel])}
yield! _Ni gel 0 1
Line 932:
{{out}}
<pre>
v<
=={{header|Forth}}==
|