Eu vejo seu BIDMAS e levanto um BADMIS
Desafio
Dado um conjunto de números com operadores entre eles: "5 + 4 * 9/3 - 8", retorne todos os resultados possíveis da expressão para cada permutação da ordem das operações básicas: [/, *, +, -].
Regras
- Lacunas padrão proibidas
- I / O
- A entrada deve ser ordenada com operações de infix, mas, no entanto, é mais fácil (sequência ou matriz)
- Você não é obrigado a oferecer suporte a operadores unários (por exemplo, "-3 * 8 / +2")
- Os números inteiros podem ser substituídos por números flutuantes para idiomas que analisam implicitamente o tipo (por exemplo, 45 ⟶ 45.0)
- A saída deve conter todos os resultados possíveis da expressão, sem formato ou ordem especificados
- Todas as entradas são válidas (por exemplo, não é necessário lidar com "7/3 + *"). Isso também significa que você nunca precisará dividir por zero.
- Os operadores são todos associativos à esquerda, então "20/4/2" = "(20/4) / 2"
- Este é o Code Golf, o menor número de bytes ganha
Casos de teste (com explicação)
- "2 + 3 * 4" = [14, 20]
- 2 + (3 * 4) ⟶ 2 + (12) ⟶ 14
- (2 + 3) * 4 ⟶ (5) * 4 ⟶ 20
- "18/3 * 2 - 1" = [11, 2, 6]
- ((18/3) * 2) - 1 ⟶ ((6) * 2) - 1 ⟶ (12) - 1 ⟶ 11
- (18/3) * (2-1) ⟶ (6) * (1) ⟶ 6
- (18 / (3 * 2)) - 1 ⟶ (18 / (6)) - 1 ⟶ (3) - 1 ⟶ 2
- 18 / (3 * (2-1)) ⟶ 18 / (3 * (1)) ⟶ 6
- 18 / ((3 * 2) - 1) ⟶ 18/5 ⟶ 3,6
Casos de teste (sem explicação)
- "45/8 + 19/45 * 3" = [6.891666666666667, 18.141666666666666, 0.1111111111111111113, 0.01234567901234568, 0.01234567901234568, 5.765740740740741]
- "2 + 6 * 7 * 2 + 6/4" = [112 196 23 87,5]
2 - 3 + 4
=>[-5, 3]
2*3-6+2-9/6*8+5/2-9
fornecendo 24 resultados distintos.