Comment Python détermine si une chaîne est un entier : 1. Méthode récursive, vous pouvez d'abord déterminer le signe de l'entier en fonction du premier caractère de la chaîne, puis parcourir la chaîne de droite à gauche ; .Non La méthode récursive est implémentée en parcourant la chaîne de gauche à droite pour calculer la valeur de l'entier.
L'environnement d'exploitation de ce tutoriel : système Windows 7, python version 3.9, ordinateur DELL G3.
Méthode Python pour déterminer si une chaîne est un entier :
Méthode 1 : Méthode récursive
Pour les entiers, Pour Par exemple, 111 peut être vu comme 11*10+1 et 11 peut être vu comme 1*10+1. Et -111 peut être considéré comme (-11)*10-1, et -11 peut être considéré comme (-1)*10-1. Selon cette fonctionnalité, une méthode récursive peut être utilisée pour résoudre le problème, ce qui peut. être déterminé en fonction du premier caractère de la chaîne. Le positif et le négatif de l'entier, puis parcourir la chaîne de droite à gauche.
class Test: def __init__(self): self.flag = None def getFlag(self): return self.flag # 判断c是否是数字,如果是返回数字,且设置flag=True,否则返回False def isNumber(self, c): return c >= '0' and c <= '9' # 判断str是否是数字 def strtoint(self, strs, length): if length > 1: if not self.isNumber(list(strs)[length - 1]): # 不是数字 print("不是数字") self.flag = False return -1 if list(strs)[0] == '-': return self.strtoint(strs, length - 1) * 10 - (ord(list[length - 1]) - ord('0')) else: return self.strtoint(strs, length - 1) * 10 + ord(list(strs)[length - 1]) - ord('0') else: if list(strs)[0] == '-': return 0 else: if not self.isNumber(list(strs)[0]): print("不是数字") self.flag = False return -1 return ord(list(strs)[0]) - ord('0') def strToint(self, s): self.flag = True if s == None or len(s) <= 0 or (list(s)[0] == '-' and len(s) == 1): print("不是数字") self.flag = False return -1 if list(s)[0] == '+': return self.strToint(s[1:len(s)], len(s) - 1) else: return self.strToint(s, len(s))
Méthode 2 : Méthode non récursive
Déterminez d'abord le positif de l'entier via la valeur d'un caractère Négativité, puis supprimez le bit de signe, traitez la chaîne suivante comme un nombre positif et renvoyez le résultat correct basé sur la positivité une fois le traitement terminé. La méthode d'implémentation consiste à parcourir la chaîne de gauche à droite pour calculer la valeur de l'entier. En prenant "123" comme exemple, lors du passage vers "2", le résultat est 1*10+2=12, et lors du passage vers "2", le résultat est 1*10+2=12. '3', le résultat est 12* 10+3=123.
class Test: def __init__(self): self.flag = None def getFlag(self): return self.flag # 判断c是否是数字,如果是返回True,否则返回False def isNumber(self, c): return c >= "0" and c <= "9" def strToint(self, strs): if strs == None: self.flag = False print("不是数字") return -1 self.flag = True res = 0 i = 0 minus = False # 是否是负数 if list(strs)[i] == '-': # 结果是负数 minus = True i += 1 if list(strs)[i] == '+': # 结果是正数 i += 1 while i < len(strs): if self.isNumber(list(strs)[i]): res = res * 10 + ord(list(strs)[i]) - ord('0') else: self.flag = False print("不是数字") return -1 i += 1 return -res if minus else res if __name__ == "__main__": t = Test() s = "-543" print(t.strToint(s)) s = "543" print(t.strToint(s)) s = "+543" print(t.strToint(s)) s = "++43" result = t.strToint(s) if t.getFlag(): print(result)
Recommandations d'apprentissage gratuites associées : Tutoriel vidéo Python
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!