Skip to content

Instantly share code, notes, and snippets.

@fabriziogiordano
Last active March 13, 2017 16:48
Show Gist options
  • Select an option

  • Save fabriziogiordano/ea4688c1f84e693ec447f75a0662a07a to your computer and use it in GitHub Desktop.

Select an option

Save fabriziogiordano/ea4688c1f84e693ec447f75a0662a07a to your computer and use it in GitHub Desktop.
generate_strings = (d, t, c, j, p, m, o) => {
console.log(
"c:", c,
"c.length:", c.length,
"j:", j,
"p:", p,
"m:", m,
"o:", o
)
if (j == d.length) {
return p == t && results.push(c);
}
for (var i = j; i < d.length; i++) {
if (!+d[j] & i > j) {
console.log('break')
break;
}
var x = +d.slice(j, i + 1);
if (c.length) {
generate_strings(d, t, c + "+" + x, i + 1, p + x, x, "segno +");
generate_strings(d, t, c + "-" + x, i + 1, p - x, -x, "segno -");
generate_strings(d, t, c + "*" + x, i + 1, p - m + m * x, x * m, "segno *");
} else {
generate_strings(d, t, c + x, i + 1, x, x, "segno neutro");
}
}
};
composeExpression = (digits, target) => {
results = [];
generate_strings(digits, target, "", 0, 0, 0, "originale");
return results.sort();
};
composeExpression('2326',14)
c: c.length: 0 j: 0 p: 0 m: 0 o: originale
c: 2 c.length: 1 j: 1 p: 2 m: 2 o: segno neutro
c: 2+3 c.length: 3 j: 2 p: 5 m: 3 o: segno +
c: 2+3+2 c.length: 5 j: 3 p: 7 m: 2 o: segno +
c: 2+3+2+6 c.length: 7 j: 4 p: 13 m: 6 o: segno +
c: 2+3+2-6 c.length: 7 j: 4 p: 1 m: -6 o: segno -
c: 2+3+2*6 c.length: 7 j: 4 p: 17 m: 12 o: segno *
c: 2+3-2 c.length: 5 j: 3 p: 3 m: -2 o: segno -
c: 2+3-2+6 c.length: 7 j: 4 p: 9 m: 6 o: segno +
c: 2+3-2-6 c.length: 7 j: 4 p: -3 m: -6 o: segno -
c: 2+3-2*6 c.length: 7 j: 4 p: -7 m: -12 o: segno *
c: 2+3*2 c.length: 5 j: 3 p: 8 m: 6 o: segno *
c: 2+3*2+6 c.length: 7 j: 4 p: 14 m: 6 o: segno +
c: 2+3*2-6 c.length: 7 j: 4 p: 2 m: -6 o: segno -
c: 2+3*2*6 c.length: 7 j: 4 p: 38 m: 36 o: segno *
c: 2+3+26 c.length: 6 j: 4 p: 31 m: 26 o: segno +
c: 2+3-26 c.length: 6 j: 4 p: -21 m: -26 o: segno -
c: 2+3*26 c.length: 6 j: 4 p: 80 m: 78 o: segno *
c: 2-3 c.length: 3 j: 2 p: -1 m: -3 o: segno -
c: 2-3+2 c.length: 5 j: 3 p: 1 m: 2 o: segno +
c: 2-3+2+6 c.length: 7 j: 4 p: 7 m: 6 o: segno +
c: 2-3+2-6 c.length: 7 j: 4 p: -5 m: -6 o: segno -
c: 2-3+2*6 c.length: 7 j: 4 p: 11 m: 12 o: segno *
c: 2-3-2 c.length: 5 j: 3 p: -3 m: -2 o: segno -
c: 2-3-2+6 c.length: 7 j: 4 p: 3 m: 6 o: segno +
c: 2-3-2-6 c.length: 7 j: 4 p: -9 m: -6 o: segno -
c: 2-3-2*6 c.length: 7 j: 4 p: -13 m: -12 o: segno *
c: 2-3*2 c.length: 5 j: 3 p: -4 m: -6 o: segno *
c: 2-3*2+6 c.length: 7 j: 4 p: 2 m: 6 o: segno +
c: 2-3*2-6 c.length: 7 j: 4 p: -10 m: -6 o: segno -
c: 2-3*2*6 c.length: 7 j: 4 p: -34 m: -36 o: segno *
c: 2-3+26 c.length: 6 j: 4 p: 25 m: 26 o: segno +
c: 2-3-26 c.length: 6 j: 4 p: -27 m: -26 o: segno -
c: 2-3*26 c.length: 6 j: 4 p: -76 m: -78 o: segno *
c: 2*3 c.length: 3 j: 2 p: 6 m: 6 o: segno *
c: 2*3+2 c.length: 5 j: 3 p: 8 m: 2 o: segno +
c: 2*3+2+6 c.length: 7 j: 4 p: 14 m: 6 o: segno +
c: 2*3+2-6 c.length: 7 j: 4 p: 2 m: -6 o: segno -
c: 2*3+2*6 c.length: 7 j: 4 p: 18 m: 12 o: segno *
c: 2*3-2 c.length: 5 j: 3 p: 4 m: -2 o: segno -
c: 2*3-2+6 c.length: 7 j: 4 p: 10 m: 6 o: segno +
c: 2*3-2-6 c.length: 7 j: 4 p: -2 m: -6 o: segno -
c: 2*3-2*6 c.length: 7 j: 4 p: -6 m: -12 o: segno *
c: 2*3*2 c.length: 5 j: 3 p: 12 m: 12 o: segno *
c: 2*3*2+6 c.length: 7 j: 4 p: 18 m: 6 o: segno +
c: 2*3*2-6 c.length: 7 j: 4 p: 6 m: -6 o: segno -
c: 2*3*2*6 c.length: 7 j: 4 p: 72 m: 72 o: segno *
c: 2*3+26 c.length: 6 j: 4 p: 32 m: 26 o: segno +
c: 2*3-26 c.length: 6 j: 4 p: -20 m: -26 o: segno -
c: 2*3*26 c.length: 6 j: 4 p: 156 m: 156 o: segno *
c: 2+32 c.length: 4 j: 3 p: 34 m: 32 o: segno +
c: 2+32+6 c.length: 6 j: 4 p: 40 m: 6 o: segno +
c: 2+32-6 c.length: 6 j: 4 p: 28 m: -6 o: segno -
c: 2+32*6 c.length: 6 j: 4 p: 194 m: 192 o: segno *
c: 2-32 c.length: 4 j: 3 p: -30 m: -32 o: segno -
c: 2-32+6 c.length: 6 j: 4 p: -24 m: 6 o: segno +
c: 2-32-6 c.length: 6 j: 4 p: -36 m: -6 o: segno -
c: 2-32*6 c.length: 6 j: 4 p: -190 m: -192 o: segno *
c: 2*32 c.length: 4 j: 3 p: 64 m: 64 o: segno *
c: 2*32+6 c.length: 6 j: 4 p: 70 m: 6 o: segno +
c: 2*32-6 c.length: 6 j: 4 p: 58 m: -6 o: segno -
c: 2*32*6 c.length: 6 j: 4 p: 384 m: 384 o: segno *
c: 2+326 c.length: 5 j: 4 p: 328 m: 326 o: segno +
c: 2-326 c.length: 5 j: 4 p: -324 m: -326 o: segno -
c: 2*326 c.length: 5 j: 4 p: 652 m: 652 o: segno *
c: 23 c.length: 2 j: 2 p: 23 m: 23 o: segno neutro
c: 23+2 c.length: 4 j: 3 p: 25 m: 2 o: segno +
c: 23+2+6 c.length: 6 j: 4 p: 31 m: 6 o: segno +
c: 23+2-6 c.length: 6 j: 4 p: 19 m: -6 o: segno -
c: 23+2*6 c.length: 6 j: 4 p: 35 m: 12 o: segno *
c: 23-2 c.length: 4 j: 3 p: 21 m: -2 o: segno -
c: 23-2+6 c.length: 6 j: 4 p: 27 m: 6 o: segno +
c: 23-2-6 c.length: 6 j: 4 p: 15 m: -6 o: segno -
c: 23-2*6 c.length: 6 j: 4 p: 11 m: -12 o: segno *
c: 23*2 c.length: 4 j: 3 p: 46 m: 46 o: segno *
c: 23*2+6 c.length: 6 j: 4 p: 52 m: 6 o: segno +
c: 23*2-6 c.length: 6 j: 4 p: 40 m: -6 o: segno -
c: 23*2*6 c.length: 6 j: 4 p: 276 m: 276 o: segno *
c: 23+26 c.length: 5 j: 4 p: 49 m: 26 o: segno +
c: 23-26 c.length: 5 j: 4 p: -3 m: -26 o: segno -
c: 23*26 c.length: 5 j: 4 p: 598 m: 598 o: segno *
c: 232 c.length: 3 j: 3 p: 232 m: 232 o: segno neutro
c: 232+6 c.length: 5 j: 4 p: 238 m: 6 o: segno +
c: 232-6 c.length: 5 j: 4 p: 226 m: -6 o: segno -
c: 232*6 c.length: 5 j: 4 p: 1392 m: 1392 o: segno *
c: 2326 c.length: 4 j: 4 p: 2326 m: 2326 o: segno neutro
(2) ["2*3+2+6", "2+3*2+6"]
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment