首页 > 其他 > 详细

例16数字判断

时间:2020-05-23 22:10:45      阅读:70      评论:0      收藏:0      [点我收藏+]

问题描述
给定一个字符串,验证其是否为数字

问题示例
0判断为true
0.1判断为true
abc判断为false
1 a判断为false
2e10判断为true

代码实现

#参数s是一个字符串,返回一个布尔值,有限的自动化

class Solution:
    def isNumber(self, s):
        INVALID=0; SPACE=1; SIGN=2; DIGIT=3; DOT=4; EXPONENT=5;
        #0无效,1空格,2符号,3数字,4小数点,5指数,6输入的数字
        transitionTable=[
            [-1,0,3,1,2,-1],
            [-1,8,-1,1,4,5],
            [-1,-1,-1,1,2,-1],
            [-1,8,-1,4,-1,5],
            [-1,-1,6,7,-1,-1],
            [-1,-1,-1,7,-1,-1],
            [-1,8,-1,7,-1,-1],
            [-1,8,-1,-1,-1,-1]
        ]
        state=0;i=0
        while i<len(s):
            inputtype=INVALID
            if s[i]==‘‘: inputtype=SPACE
            elif s[i]==‘-‘ or s[i]==‘+‘:inputtype=SIGN
            elif s[i] in ‘0123456789‘:inputtype=DIGIT
            elif s[i]==‘.‘:inputtype=DOT
            elif s[i]==‘e‘ or s[i]==‘E‘:inputtype=EXPONENT
            state=transitionTable[state][inputtype]
            if state==-1:return False
            else: i+=1
        return state==1 or state==4 or state==7 or state==8

if __name__ == "__main__":
    temp=Solution()
    string1="1"
    string2="23aa"
    print("输入:"+string1)
    print("输出:"+str(temp.isNumber(string1)))
    print("输入:"+string2)
    print("输出:"+str(temp.isNumber(string2)))

运行结果
输入1
输出True
输入23aa
输出False

返回目录

例16数字判断

原文:https://www.cnblogs.com/hankleo/p/12944253.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!