Skip to content

Instantly share code, notes, and snippets.

@demobo-com
Last active August 10, 2018 02:32
Show Gist options
  • Save demobo-com/f05851b54b0eb3bbab3a8d3f42474f6c to your computer and use it in GitHub Desktop.
Save demobo-com/f05851b54b0eb3bbab3a8d3f42474f6c to your computer and use it in GitHub Desktop.
const _ = require('lodash');
const getCombination = arr => i => arr.filter((v,j) => i & Math.pow(2, j));
const solve = (a, b) => {
const unders = a.length > b.length ? b : a;
const ups = a.length > b.length ? a : b;
if (!unders.length || !ups.length) return 0;
const m = Math.pow(2, unders.length);
const n = Math.pow(2, ups.length);
const getUndersCombination = getCombination(unders);
const getUpsCombination = getCombination(ups);
const underSumMap = {};
for (var i = 0; i < m; i++) {
const targetSum = _.sum(getUndersCombination(i));
if (!underSumMap[targetSum]) underSumMap[targetSum] = i;
}
let undersIndex, upsIndex;
for (var j = 1; j < n - 1; j++) {
const targetSum = _.sum(getUpsCombination(j));
undersIndex = underSumMap[targetSum];
upsIndex = j;
if (undersIndex) break;
}
if (!undersIndex) return unders.length + ups.length - 1;
return solve(getUndersCombination(undersIndex), getUpsCombination(upsIndex))
+
solve(getUndersCombination(m - 1 - undersIndex), getUpsCombination(n - 1 - upsIndex));
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment