热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

leetcode每日一题65.有效数字

DFA法思路:确定的有穷自动机,相关参考8.字符串转换整数(atoi)遍历字符串,遇到的字符总共有6种。(空格,正负号,数字,小数点,字符e,无效字符)可能出现的状态有11种:st

技术分享图片

DFA法

思路:

确定的有穷自动机,相关参考8. 字符串转换整数 (atoi)

 

遍历字符串,遇到的字符总共有6种。(空格,正负号,数字,小数点,字符e,无效字符)

可能出现的状态有11种:

start:初始状态

signed:符号态

integer:整数态

sDot:特殊的初始小数点态(小数点之前为符号或空格)

dot:小数点态(小数之前为整数)

decimals:小数态

e:指数符号态

eSigned:指数正负号态

index:指数态

eSpace:尾部空格态

end:无效截止态

各种状态在自己状态下遇到6种字符要更新的状态如下图所示:

技术分享图片

每种状态下代表之前遍历过的字符是否能转为数字:

start:False

signed:False

integer:True

sDot:False

dot:True

decimals:True

e:False

eSigned:False

index:True

eSpace:True

end:False

代码:


class Automaton:
def __init__(self):
self.state
= start
self.isNum
= False
self.table
= {
start: [start,signed,integer,sDot, end,end],
signed: [end,end,integer,sDot,end, end],
integer: [eSpace,end,integer,dot,e,end],
sDot:[end,end,decimals,end,end,end],
dot: [eSpace,end,decimals,end,e,end],
decimals: [eSpace,end,decimals,end,e,end],
e: [end,eSigned,index,end,end,end],
eSigned: [end,end,index,end,end,end],
index: [eSpace,end,index,end,end,end],
eSpace: [eSpace,end,end,end,end,end]
}
def get_col(self, c):
if c.isspace():
return 0
if c == + or c == -:
return 1
if c.isdigit():
return 2
if c == .:
return 3
if c == e:
return 4
return 5
def get(self, c):
self.state
= self.table[self.state][self.get_col(c)]
if self.state == start:
self.isNum
= False
elif self.state == signed:
self.isNum
= False
elif self.state == integer:
self.isNum
= True
elif self.state == sDot:
self.isNum
= False
elif self.state == dot:
self.isNum
= True
elif self.state == decimals:
self.isNum
= True
elif self.state == e:
self.isNum
= False
elif self.state == eSigned:
self.isNum
= False
elif self.state == index:
self.isNum
= True
elif self.state == end:
self.isNum
= False
elif self.state == eSpace:
self.isNum
= True
class Solution:
def isNumber(self, s: str) -> bool:
automaton
= Automaton()
for c in s:
automaton.get(c)
if automaton.state == "end":
break
return automaton.isNum

 


推荐阅读
  • 创建项目:Visual Studio Online 入门指南
    本文介绍如何使用微软的 Visual Studio Online(VSO)创建和管理开发项目。作为一款基于云计算的开发平台,VSO 提供了丰富的工具和服务,简化了项目的配置和部署流程。 ... [详细]
  • 本文详细探讨了 Django 的 ORM(对象关系映射)机制,重点介绍了其如何通过 Python 元类技术实现数据库表与 Python 类的映射。此外,文章还分析了 Django 中各种字段类型的继承结构及其与数据库数据类型的对应关系。 ... [详细]
  • 本文介绍了 Winter-1-C A + B II 问题的详细解题思路和测试数据。该问题要求计算两个大整数的和,并输出结果。我们将深入探讨如何处理大整数运算,确保在给定的时间和内存限制下正确求解。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 本文介绍了如何使用Java中的同步方法和同步代码块来实现两个线程的交替打印。一个线程负责打印1到52的数字,另一个线程负责打印A到Z的字母,确保输出顺序为12A34B...5152Z。 ... [详细]
  • 通过Web界面管理Linux日志的解决方案
    本指南介绍了一种利用rsyslog、MariaDB和LogAnalyzer搭建集中式日志管理平台的方法,使用户可以通过Web界面查看和分析Linux系统的日志记录。此方案不仅适用于服务器环境,还提供了详细的步骤来确保系统的稳定性和安全性。 ... [详细]
  • 探讨了在有序数列中实现多种查询和修改操作的高效数据结构设计,主要使用线段树与平衡树(Treap)结合的方法。 ... [详细]
  • 深入理解T-SQL中的NULL与三值逻辑
    本文探讨了SQL Server中的三值逻辑,解释了谓词计算结果为TRUE、FALSE和UNKNOWN的规则。通过具体示例,详细说明了如何正确处理NULL值,并探讨了在不同约束条件下的行为。 ... [详细]
  • TechStride 网站
    TechStride 成立于2014年初,致力于互联网前沿技术、产品创意及创业内容的聚合、搜索、学习与展示。我们旨在为互联网从业者提供更高效的新技术搜索、学习、分享和产品推广平台。 ... [详细]
  • Qt中QSpinBox与QSlider的联动实现
    本文介绍如何在Qt框架下将QSpinBox和QSlider组件进行联动,使用户在拖动滑块或修改文本框中的数值时,两个组件能同步更新,从而提供更加直观和便捷的用户体验。 ... [详细]
  • Redis Hash 数据结构详解
    本文详细介绍了 Redis 中的 Hash 数据类型及其常用命令。Hash 类型用于存储键值对集合,支持多种操作如插入、查询、更新和删除字段值。此外,文章还探讨了 Hash 类型在实际业务场景中的应用,并提供了优化建议。 ... [详细]
  • HDU 1394:线段树优化求解逆序对问题
    本文介绍如何使用线段树高效求解排列中的逆序对问题。通过单点增减和区间求和操作,线段树能够快速处理此类问题,并提供了一种替代树状数组的解决方案。 ... [详细]
  • MySQL DateTime 类型数据处理及.0 尾数去除方法
    本文介绍如何在 MySQL 中处理 DateTime 类型的数据,并解决获取数据时出现的.0尾数问题。同时,探讨了不同场景下的解决方案,确保数据格式的一致性和准确性。 ... [详细]
  • 作为一名 Ember.js 新手,了解如何在路由和模型中正确加载 JSON 数据是至关重要的。本文将探讨两者之间的差异,并提供实用的建议。 ... [详细]
author-avatar
手机用户2502852661
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有