Skip welcome & menu and move to editor
Welcome to JS Bin
Load cached copy from
 
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width">
  <title>JS Bin</title>
</head>
<body>
</body>
</html>
 
var generatePermutations = function (items, process) {
  "use strict";
  var 
    mutableItems = items.slice(),
    isEven = function (n) {
      return (n & 1) === 0;
    },
    permute = function (itemArray, x, last) {
      if (isEven(last)) { x = 0; }
      var temp = itemArray[x];
      itemArray[x] = itemArray[last];
      itemArray[last] = temp;
    },
    generate = function generateNext(last, process) {
      var i;
      if (last === 0) {
        process(mutableItems);
      }
      else {
        for (i = 0; i < last; i += 1) {
          generateNext(last - 1, process);
          permute(mutableItems, i, last);
        }
        generateNext(last - 1, process);
      }
    };
  if (mutableItems.length > 0)
    generate(mutableItems.length - 1, process);
};
generatePermutations(["A","B"],console.log);
generatePermutations([1],console.log);
generatePermutations([],console.log);
Output

You can jump to the latest bin by adding /latest to your URL

Dismiss x
public
Bin info
anonymouspro
0viewers