Maison  >  Article  >  développement back-end  >  Comment déterminer si une chaîne est un entier en Python

Comment déterminer si une chaîne est un entier en Python

coldplay.xixi
coldplay.xixioriginal
2021-03-16 15:57:2721358parcourir

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.

Comment déterminer si une chaîne est un entier en Python

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 >= &#39;0&#39; and c <= &#39;9&#39;
 
    # 判断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] == &#39;-&#39;:
                return self.strtoint(strs, length - 1) * 10 - (ord(list[length - 1]) - ord(&#39;0&#39;))
            else:
                return self.strtoint(strs, length - 1) * 10 + ord(list(strs)[length - 1]) - ord(&#39;0&#39;)
 
        else:
            if list(strs)[0] == &#39;-&#39;:
                return 0
            else:
                if not self.isNumber(list(strs)[0]):
                    print("不是数字")
                    self.flag = False
                    return -1
                return ord(list(strs)[0]) - ord(&#39;0&#39;)
 
    def strToint(self, s):
        self.flag = True
        if s == None or len(s) <= 0 or (list(s)[0] == &#39;-&#39; and len(s) == 1):
            print("不是数字")
            self.flag = False
            return -1
 
        if list(s)[0] == &#39;+&#39;:
            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] == &#39;-&#39;:  # 结果是负数
            minus = True
            i += 1
 
        if list(strs)[i] == &#39;+&#39;:  # 结果是正数
            i += 1
        while i < len(strs):
            if self.isNumber(list(strs)[i]):
                res = res * 10 + ord(list(strs)[i]) - ord(&#39;0&#39;)
            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!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn