Maison >développement back-end >Tutoriel Python >Comment utiliser les expressions régulières Python pour l'évaluation inversée des expressions polonaises
Qu'est-ce que l'expression polonaise inversée ?
L'expression polonaise inversée, également connue sous le nom d'expression postfixe, est une méthode d'expression d'expressions arithmétiques qui ne nécessite pas de parenthèses pour distinguer la priorité des opérateurs. Sa particularité est que l'opérateur est derrière l'opérande. Par exemple, la conversion de l'expression infixe « 3 + 4 5 » en expression polonaise inversée est « 3 4 5 + ».
Que sont les expressions régulières Python ?
Les expressions régulières Python sont des outils de mise en correspondance et de traitement de données textuelles. Les expressions régulières peuvent être utilisées pour rechercher des modèles dans le texte. Python fournit le module "re" pour utiliser la fonctionnalité d'expression régulière.
Comment utiliser les expressions régulières Python pour l'évaluation inversée des expressions polonaises ?
La mise en œuvre de l'algorithme d'évaluation de l'expression polonaise inversée nécessite de suivre les étapes suivantes :
Nous pouvons utiliser des expressions régulières Python pour implémenter facilement la fonction de conversion d'expressions polonaises inversées en listes. L'exemple de code est le suivant :
import re expression = "3 4 5 * +" tokens = re.findall("d+|S", expression) print(tokens) # ['3', '4', '5', '*', '+']
Ensuite, nous pouvons suivre les étapes ci-dessus pour implémenter l'algorithme d'évaluation de l'expression polonaise inversée. L'exemple de code est le suivant :
stack = [] for token in tokens: if re.match("d+", token): stack.append(int(token)) else: operand2 = stack.pop() operand1 = stack.pop() if token == "+": stack.append(operand1 + operand2) elif token == "-": stack.append(operand1 - operand2) elif token == "*": stack.append(operand1 * operand2) elif token == "/": stack.append(int(operand1 / operand2)) result = stack.pop() print(result) # 23
Ce code fonctionne en créant une pile vide, en parcourant la liste des expressions polonaises inversées, en vérifiant chaque opérateur et opérande, en effectuant l'opération correspondante sur la pile et enfin en renvoyant l'élément en haut de la pile comme résultat.
Conclusion
En utilisant les expressions régulières Python, vous pouvez facilement convertir des expressions polonaises inversées en listes et effectuer des calculs arithmétiques sur la pile. Les expressions régulières de Python sont très puissantes et peuvent nous aider à obtenir une correspondance et un traitement de texte rapides, flexibles et fiables.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!