Je vois votre BIDMAS et vous élève un BADMIS
Défi
Etant donné un ensemble de nombres avec des opérateurs entre eux: "5 + 4 * 9/3 - 8", retourne tous les résultats possibles de l'expression pour chaque permutation de l'ordre des opérations de base: [/, *, +, -].
Règles
- Failles standard interdites
- E / S
- L'entrée doit être ordonnée avec des opérations d'infixe, mais cependant c'est plus simple (chaîne ou tableau)
- Vous n'êtes pas tenu de prendre en charge les opérateurs unaires (par exemple, "-3 * 8 / +2")
- Les entiers peuvent être remplacés par des flottants pour les langues qui analysent implicitement le type (par exemple 45 ⟶ 45.0)
- La sortie doit être tous les résultats possibles de l'expression, aucun format ni ordre spécifié
- Toutes les entrées sont valides (par exemple n'ont pas besoin de traiter avec "7/3 + *"). Cela signifie également que vous n'aurez jamais besoin de diviser par zéro.
- Les opérateurs sont tous associatifs à gauche, donc "20/4/2" = "(20/4) / 2"
- C'est Code Golf, donc le moins d'octets gagne
Cas de test (avec explication)
- "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
Cas de test (sans explication)
- "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
donnant 24 résultats distincts.