在剑指offer上看到的题目,输入一个请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100","5e2","-123","3.1416"和"-1E-16"都表示数值。 但是"12e","1a3.14","1.2.3","+-5"和"12e+4.3"都不是。
也就是用正则式匹配来解决问题,表示数字的字符串遵循模式A[.[B]][e|EC]或者.B[e|EC]
本来是用c++写的答案,在看答案区的评论的时候发现有人也用python写了,一行代码解决问题,是调用了re模块进行正则式匹配
# -*- coding:utf-8 -*- import re class Solution: def isNumeric(self, s): return re.match(r"^[\+\-]?[0-9]*(\.[0-9]*)?([eE][\+\-]?[0-9]+)?$",s)刚好也在学习python部分的正则式,加深一下理解。在运行时可以很明显的发现,c++的运行时间要比python快很多。主要也是因为c++是编译语言直接使用机器指令,而python是解释型语言逻辑转换为机器指令。