Best shuffle: Difference between revisions

Line 2,218:
=={{header|Rascal}}==
<lang Rascal>import Prelude;
 
public tuple[str, str, int] bestShuffle(str s){
characters = chars(s);
 
ranking = {<p, comparePcountSame(p, characters)> | p <- permutations(characters)};
best = {<s, stringChars(p), n> | <p, n> <- ranking, n == min(range(ranking))};
return takeOneFrom(best)[0];
}
 
public int comparePcountSame(list[int] permutations, list[int] characters){
return (0 | it + 1 | n <- index(characters), permutations[n] == characters[n]);
}</lang>
}
</lang>
 
=={{header|REXX}}==
Anonymous user