Skip to content

679. 24 Game

Description

You are given an integer array cards of length 4. You have four cards, each containing a number in the range [1, 9]. You should arrange the numbers on these cards in a mathematical expression using the operators ['+', '-', '*', '/'] and the parentheses '(' and ')' to get the value 24.

You are restricted with the following rules:

  • The division operator '/' represents real division, not integer division.
    • For example, 4 / (1 - 2 / 3) = 4 / (1 / 3) = 12.
  • Every operation done is between two numbers. In particular, we cannot use '-' as a unary operator.
    • For example, if cards = [1, 1, 1, 1], the expression "-1 - 1 - 1 - 1" is not allowed.
  • You cannot concatenate numbers together
    • For example, if cards = [1, 2, 1, 2], the expression "12 + 12" is not valid.

Return true if you can get such expression that evaluates to 24, and false otherwise.

 

Example 1:

Input: cards = [4,1,8,7]
Output: true
Explanation: (8-4) * (7-1) = 24

Example 2:

Input: cards = [1,2,1,2]
Output: false

 

Constraints:

  • cards.length == 4
  • 1 <= cards[i] <= 9

 

Solutions

Solution: Backtracking

  • Time complexity: O(2n)
  • Space complexity: O(2n)

 

JavaScript

js
/**
 * @param {number[]} cards
 * @return {boolean}
 */
const judgePoint24 = function (cards) {
  if (cards.length === 1) return Math.abs(cards[0] - 24) < 1e-6;

  const n = cards.length;

  const getValues = (a, b) => {
    const values = [a + b, a * b, a - b, b - a];

    if (a) values.push(b / a);
    if (b) values.push(a / b);
    return values;
  };

  for (let a = 1; a < n; a++) {
    for (let b = 0; b < a; b++) {
      const values = getValues(cards[a], cards[b]);
      const nextCards = cards.filter((_, index) => index !== a && index !== b);

      for (const value of values) {
        nextCards.push(value);
        if (judgePoint24(nextCards)) return true;
        nextCards.pop();
      }
    }
  }
  return false;
};

Released under the MIT license