Hard
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:
'/' represents real division, not integer division.
4 / (1 - 2 / 3) = 4 / (1 / 3) = 12.'-' as a unary operator.
cards = [1, 1, 1, 1], the expression "-1 - 1 - 1 - 1" is not allowed.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 == 41 <= cards[i] <= 9import kotlin.math.abs
class Solution {
private fun backtrack(list: Array<Double>, n: Int): Boolean {
if (n == 1) {
return abs(list[0] - 24) < EPS
}
for (i in 0 until n) {
for (j in i + 1 until n) {
val a = list[i]
val b = list[j]
list[j] = list[n - 1]
list[i] = a + b
if (backtrack(list, n - 1)) {
return true
}
list[i] = a - b
if (backtrack(list, n - 1)) {
return true
}
list[i] = b - a
if (backtrack(list, n - 1)) {
return true
}
list[i] = a * b
if (backtrack(list, n - 1)) {
return true
}
if (Math.abs(b) > EPS) {
list[i] = a / b
if (backtrack(list, n - 1)) {
return true
}
}
if (Math.abs(a) > EPS) {
list[i] = b / a
if (backtrack(list, n - 1)) {
return true
}
}
list[i] = a
list[j] = b
}
}
return false
}
fun judgePoint24(nums: IntArray): Boolean {
val a = nums.map { it.toDouble() }.toTypedArray()
return backtrack(a, a.size)
}
companion object {
private const val EPS = 1e-6
}
}