From deebb9f96be9e9f8c8b07bbb07bf32dd074c8e36 Mon Sep 17 00:00:00 2001 From: Josh Parker Date: Fri, 8 Mar 2024 04:28:55 -0700 Subject: [PATCH] add the solver for the words with two fake letters and one hidden letter --- gmw/cheat-wos.user.js | 41 ++++++++++++++++++++++++++++++++++++----- 1 file changed, 36 insertions(+), 5 deletions(-) diff --git a/gmw/cheat-wos.user.js b/gmw/cheat-wos.user.js index 163e5b5..1fbaf80 100644 --- a/gmw/cheat-wos.user.js +++ b/gmw/cheat-wos.user.js @@ -15,7 +15,7 @@ const pointValues = { n: 1, o: 1, p: 3, - q: 1, + q: 10, r: 1, s: 1, t: 1, @@ -145,7 +145,7 @@ const solveFake = (scramble, length, prefixTreeRoot = dictTrees[length]) => { const preSolve = makeSolve(1); -const solveHidden = (scramble, length) => { +const solveHidden = (scramble, length = scramble.length) => { const preDict = makePrefixTree(preSolve(scramble, length)); return [...abc].map((c) => solveFake(scramble + c, length, preDict)); }; @@ -161,8 +161,27 @@ const solveAndFilterHidden = (scramble, length, targetCount) => { return !seen; })); - // sort in ascending order of number of words - return dedupedSolutions.sort((a, b) => a.length - b.length); + return dedupedSolutions; +}; + +const solveAndDisplayHidden = (scramble, length, targetCount, otherTargets) => { + const dedupedSolutions = solveAndFilterHidden(scramble, length, targetCount); + const fullSolutions = dedupedSolutions.map((solution) => ( + otherTargets.map((target) => ( + solve(solution[0], target[0]) + )).concat(solution) + )).filter((solution) => ( + solution.every((otherSolution, i) => ( + (i >= otherTargets.length) + || (otherSolution.length >= otherTargets[i][1]) + )) + )); + + const displaySolutions = fullSolutions.map((solution) => ( + solution.flat().map((word) => `${word} ${score(word)}`).join(' ') + )); + + return displaySolutions.sort((a, b) => a.length - b.length); }; // Next: Solve for two fake and one hidden. @@ -174,6 +193,18 @@ const display = (solutions) => ( Number(b.match(/\d+/)) - Number(a.match(/\d+/)) )))); +const solveHiddenFakeX2 = (scramble, length = scramble.length - 1) => { + const preDict = makePrefixTree(preSolve(scramble, length)); + const doubleFakes = new Set(fake(scramble).map((faked) => fake(faked)).flat()); + return [...doubleFakes].map((e) => [...abc].map((c) => solve(e + c, length, preDict))); +}; + export default { - solve, solveFake, solveHidden, display, solveAndFilterHidden, + solve, + solveFake, + solveHidden, + display, + solveAndFilterHidden, + solveAndDisplayHidden, + solveHiddenFakeX2, };