8. String to Integer (atoi)

1题目理解

输入:一个字符串s,可能包含空格、正负号、数字,还有其他字符。
输出:将字符串转为int
规则:字符串s一开始可能有很多空格,可以忽略这些空格,直到遇到第一个非空字符。从这个字符开始,根据正负号返回int数字。
从开始计数起,也可能会遇到其他字符,忽略。这些字符对答案没有影响。
如果第一个非空格字符不是数字或者正负号,或者字符串中不存在有效的int表示形式,则返回0,不参与计算。
如果计算的数字超出了整数范围,则返回INT_MAX(231−1)INT\_MAX (2^{31} − 1)INT_MAX(2311) 或者 INT_MIN(−231)INT\_MIN (−2^{31})INT_MIN(231)

2 思路

文章来源力扣官方解释。

在处理之前的状态称为start。如果遇到的第一个字符是空格,则仍然处于start状态。如果遇到的是正负号,则可以标记正负号,进入signed状态。如果遇到的是数字,则进入计数状态(in_number),如果遇到的是其他字符则进入结束状态(end)。

根据上一步描述:可能会有signed、in_number、end三种状态。
如果进入signed状态,遇到空格,则进入end;遇到正负号,则进入end;遇到数字,则进入in_number;遇到其他字符,则进入end。

如果进入in_number状态,遇到空格,则进入end;遇到正负号,则进入end;遇到数字,则进入in_number;遇到其他字符,则进入end。

如果进入end状态,遇到什么都是进入end状态。
在这里插入图片描述

public class StringToInteger8 {public int myAtoi(String s) {AutoMation autoMation = new AutoMation();int n = s.length();for(int i=0;i<n;i++){autoMation.get(s.charAt(i));}return (int)(autoMation.sign * autoMation.answer);}class AutoMation{int sign = 1;long answer;String state = "start";Map<String,String[]> table = new HashMap<String,String[]>(){{put("start",new String[]{"start","signed","in_number","end"});put("signed",new String[]{"end","end","in_number","end"});put("in_number",new String[]{"end","end","in_number","end"});put("end",new String[]{"end","end","end","end"});}};public void get(char ch) {if(ch==' '){state = table.get(state)[0];}else if(ch=='-'|| ch=='+'){state = table.get(state)[1];}else if(ch>='0' && ch<='9'){state = table.get(state)[2];}else{state = table.get(state)[3];}if(state.equals("signed")){sign = (ch=='-'?-1:1);}else if(state.equals("in_number")){answer = answer*10+(ch-'0');if(sign==1){answer = Math.min(answer,(long)Integer.MAX_VALUE);}else{answer = Math.min(answer,(long)Integer.MIN_VALUE*-1);}}}}
}

心得:我最开始是打算用if else处理的。看了分析过程,看了代码实现,心服口服。很棒,学习了。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/424273.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

程序编码应保持良好的规范(C#)

呵呵&#xff0c;这个简直是超级老生常谈了。但我还是希望能让更多的程序员能了解一些细节习惯对于程序阅读性的影响。而这个很大程度决定了程序的可移植性。1。变量赋值之间注意保留空格。有些程序员往往不注意。不好的&#xff1a; Body.txtVersion.Textib.Version.ToString(…

第九十二期:多少程序员注意到了「中台」的背面?

中台这个词&#xff0c;最近两年特别火&#xff0c;它的爆发源于2015年张勇在阿里发出的内部信中提到的“大中台&#xff0c;小前台”战略。随后吸引了很多人开始“追逐”它。也有很多人开始借着这概念来挣钱。 作者&#xff1a;跨界架构师 这篇文章比较长&#xff0c;有5200…

框架学习 Spring之依赖注入DI

依赖注入的方式有四种&#xff1a; 1、Setter注入&#xff08;属性注入&#xff09; 2、构造器注入 3、P命名空间注入 4、集合类型值注入 1、Setter注入&#xff08;属性注入&#xff09; Employee 员工实体类 package com.spring.pojo;public class Employee {private Integer…

图:两点之间的最短距离

文章出处&#xff1a;极客时间《数据结构和算法之美》-作者&#xff1a;王争。该系列文章是本人的学习笔记。 1 问题阐述 像 Google 地图、百度地图、高德地图这样的地图软件&#xff0c;如果想从家开车到公司&#xff0c;你只需要输入起始、结束地址&#xff0c;地图就会给你…

spring mvc学习(10):eclipse的环境前maven配置

一.maven的安装 1解压maven压缩包到某一路径下 2配置MAVEN_HOME 3配置path到MAVEN_HOME/bin下 二eclipse集成MAVEN 方法1:直接使用自带插件 1在用户目录/.m2文件夹下面创建setting.xml文件&#xff0c;配置maven仓库位置 2在eclipse中直接配置maven的文件路径 方法2&…

for in / for of 要会用

for in是ES5标准&#xff0c;遍历index ---索引 or key --- 键. 1 for (var index in arr){} // index 0 1 2 3...arr.length-1 1 for (var key in obj){} // key obj里边enumerable的属性&#xff08;可枚举的属性&#xff09; for of是ES6标准&#xff0c;遍历value---每…

04级函授计算机等级考试练习.rar

04级函授计算机等级考试练习.rar 以下是计算机基础的练习资料:函授练习.rar posted on 2005-07-16 21:11 麦子 阅读(...) 评论(...) 编辑 收藏 转载于:https://www.cnblogs.com/maixf/archive/2005/07/16/194254.html

162. Find Peak Element

文章目录1 题目理解2 线性扫描3 递归二分查找1 题目理解 输入&#xff1a;int[] nums并且 nums[i]!nums[i1] 输出&#xff1a;找到称为峰值的那个数字&#xff0c;返回其下标。 规则&#xff1a;峰值是指&#xff1a;nums[i-1]<nums[i] 并且 nums[i1]<nums[i]。你可以认…

spring mvc学习(11):eclipse的环境maven项目创建前期工作

1创建maven项目 2pom.xml有红色错误&#xff0c;生成web目录 3修改pom.xml配置 <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0"xmlns:xsi"http://www.w3.org/2001/XMLSchema-instan…

第二章《蜂群思维》

白痴的选举大厅&#xff0c;由白痴选白痴&#xff0c;其产生的效果却极为惊人。蜂群曾如同日蚀一样神秘、深不可测&#xff0c;他们如同被释放的精灵一样从蜂巢涌出来&#xff0c;并缓缓漂移到另一个新的世界里去。这之中没有绝对的统治者&#xff0c;他们通过侦查员的探测&…

Visual Studio.Net 快捷键表

快捷键 功能CTRL SHIFT B生成解决方案CTRL F7 生成编译CTRL O 打开文件CTRL SHIFT O打开项目CTRL SHIFT C显示类视图窗口F4 显示属性窗口SHIFT F4显示项目属性窗口CTRL SHIFT E显示资源视图F12 转到定义CTRL F12转到声明CTRL ALT J…

69. Sqrt(x)

1 题目理解 输入一个x&#xff0c;返回这个数据的平方根。如果平方跟不是整数&#xff0c;就只取整数部分。 例如x4&#xff0c;返回2&#xff1b;x8&#xff0c;返回2。 2 二分 套用模板&#xff0c;要找一个g(x)函数。g(m)m*m>x&#xff0c;找这个函数的最小值。一个数…

spring mvc学习(12)---使用idea创建第一个maven项目

一.准备条件&#xff1a; 1.安装idea旗舰版 2.安装tomcat 二.打开idea开始创建 1.创建Project 2.选择项目类型为maven 3.输入组名和项目名 ---> 下一步 ---->下一步 4.maven项目创建完成 5.运行 &#xff08;1&#xff09;配置tomcate (2)添加tomcat &#xff08;3&…

Mybaties配置一对多关系sql实例

<!-- resultMap中的type表示返回什么类型的对象 --><resultMap id"BaseGoods" type"com.cn.hjsj.pojo.BaseGoods"><!-- property 表示com.cn.hjsj.pojo.BaseGoods中的属性&#xff1b; column 表示表中的列名 --><!-- association字面…

深入浅出.NET泛型编程(1)

深入浅出.NET泛型编程(1) 使用泛型集合  .NET 2.0的System.Collections.Generics 命名空间包含了泛型集合定义。各种不同的集合/容器类都被"参数化"了。为使用它们,只需简单地指定参数化的类型即可。请看例2:例2.类型安全的泛型列表List&#xff1c;int&#xff1e…

74. Search a 2D Matrix

文章目录1 题目理解2 二分1 题目理解 输入&#xff1a;一个mxn的int数组matrix&#xff0c;这个数组每一行按照从小到大排序&#xff0c;并且下一行的第一个值大于上一行的最后一个值。一个int值target 返回&#xff1a;target在matrix中是否存在。存在返回true。 2 二分 我…

spring mvc学习(13)windows上安装maven

本地安装与配置&#xff1a; 1.jdk 在cmd中运行 Java -version 2.下载maven包 https://maven.apache.org/download.cgi下载最新版的Maven程序&#xff1a;&#xff08;选择bin zip包&#xff09; 将文件解压在D:\Program Files\apache-maven-3.5.4 3.下载eclipse并安装 …

vmware 5.51 下安装Ubuntu Linux8.04安装vmware tools不成功

得空安装Ubuntu Linux体验一把&#xff0c;记得最早还是98,99,2000年的时候玩的&#xff0c;什么冲浪(Xteam)、红帽子、红旗、蓝点&#xff0c;TurboLinux. 那时候版本都是什么1.0,2.0,3.0之类的&#xff0c; 好像Turbo Linux版本最高到4.0了。 如今已经很少有人知道蓝点Linux了…

拜拉特夜

拜拉特夜(Barat)又称“赦免之夜”&#xff0c;指伊斯兰教历舍尔巴尼月&#xff08;八月&#xff09;十五这日的夜晚。“拜拉特”意为“无辜、清白”&#xff0c;引申为“赦免”之意。这一夜安拉将更换所有人下一年命运的“文卷”&#xff0c;所以这是忏悔之夜、讨白之夜。穆斯林…

歌谣带你看java面试题

面试题来源与各个网站&#xff0c;如有不合理之处&#xff0c;欢迎吐槽。 第一题.java面试题1 牛客&#xff1a;A派生出子类B&#xff0c;B派生出子类C&#xff0c;并且在java源代码中有如下声明&#xff1a; 第二题.java面试题2 牛客:定义类中成员变量时不可能用到的修饰是 …