#! /usr/bin/node "use strict" function combinations(arr, k) { let c = []; for (let i = 0; i < k; i++) { c.push(i); } c.push(arr.length); c.push(0); let out = []; while (true) { let inner = []; for (let i = k-1; i >= 0; i--) { inner.push(arr[c[i]]); } out.push(inner); let j = 0; while (c[j] + 1 == c[j + 1]) { c[j] = j; j += 1; } if (j >= k) { break; } c[j] += 1; } return out; } function reversepairs(a) { return combinations(a, 2).filter (v => v[1] > 2 * v[0]).length; } if (reversepairs([1, 3, 2, 3, 1]) == 2) { process.stdout.write("Pass"); } else { process.stdout.write("FAIL"); } process.stdout.write(" "); if (reversepairs([2, 4, 3, 5, 1]) == 3) { process.stdout.write("Pass"); } else { process.stdout.write("FAIL"); } process.stdout.write("\n");