力扣第八题——字符串转换整数

打印 上一主题 下一主题

主题 1804|帖子 1804|积分 5412

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
标题先容

   请你来实现一个 myAtoi(string s) 函数,使其能将字符串转换成一个 32 位有符号整数。
  函数 myAtoi(string s) 的算法如下:
  

  • 空格:读入字符串并抛弃无用的前导空格(" ")
  • 符号:查抄下一个字符(假设还未到字符末端)为 '-' 还是 '+'。假如两者都不存在,则假定结果为正。
  • 转换:通过跳过前置零来读取该整数,直到碰到非数字字符或到达字符串的结尾。假如没有读取数字,则结果为0。
  • 舍入:假如整数数超过 32 位有符号整数范围 [−231,  231 − 1] ,须要截断这个整数,使其保持在这个范围内。详细来说,小于 −231 的整数应该被舍入为 −231 ,大于 231 − 1 的整数应该被舍入为 231 − 1 。
  返回整数作为最闭幕果。
  
  示例 1:
  输入:s = "42"
  输出:42
  表明:加粗的字符串为已经读入的字符,插入符号是当前读取的字符。
  1. 带下划线线的字符是所读的内容,插入符号是当前读入位置。
  2. 第 1 步:"42"(当前没有读入字符,因为没有前导空格)
  3.          ^
  4. 第 2 步:"42"(当前没有读入字符,因为这里不存在 '-' 或者 '+')
  5.          ^
  6. 第 3 步:"<u>42</u>"(读入 "42")
  7.            ^
复制代码
示例 2:
  输入:s = " -042"
  输出:-42
  表明:
  1. 第 1 步:"<u><strong>   </strong></u>-042"(读入前导空格,但忽视掉)
  2.             ^
  3. 第 2 步:"   <u>-</u>042"(读入 '-' 字符,所以结果应该是负数)
  4.              ^
  5. 第 3 步:"   <u>-042</u>"(读入 "042",在结果中忽略前导零)
  6.                ^
复制代码
示例 3:
  输入:s = "1337c0d3"
  输出:1337
  表明:
  1. 第 1 步:"1337c0d3"(当前没有读入字符,因为没有前导空格)
  2.          ^
  3. 第 2 步:"1337c0d3"(当前没有读入字符,因为这里不存在 '-' 或者 '+')
  4.          ^
  5. 第 3 步:"1337c0d3"(读入 "1337";由于下一个字符不是一个数字,所以读入停止)
  6.              ^
复制代码
示例 4:
  输入:s = "0-1"
  输出:0
  表明:
  1. 第 1 步:"0-1" (当前没有读入字符,因为没有前导空格)
  2.          ^
  3. 第 2 步:"0-1" (当前没有读入字符,因为这里不存在 '-' 或者 '+')
  4.          ^
  5. 第 3 步:"<u>0</u>-1" (读入 "0";由于下一个字符不是一个数字,所以读入停止)
  6.           ^
复制代码
示例 5:
  输入:s = "words and 987"
  输出:0
  表明:
  读取在第一个非数字字符“w”处停止。
  
  提示:
  

  • 0 <= s.length <= 200
  • s 由英文字母(大写和小写)、数字(0-9)、' '、'+'、'-' 和 '.' 组成
  完整代码

  1. class Solution {
  2.     public int myAtoi(String str) {
  3.         Automaton automaton = new Automaton();
  4.         int length = str.length();
  5.         for (int i = 0; i < length; ++i) {
  6.             automaton.get(str.charAt(i));
  7.         }
  8.         return (int) (automaton.sign * automaton.ans);
  9.     }
  10. }
  11. class Automaton {
  12.     public int sign = 1;
  13.     public long ans = 0;
  14.     private String state = "start";
  15.     private Map<String, String[]> table = new HashMap<String, String[]>() {{
  16.         put("start", new String[]{"start", "signed", "in_number", "end"});
  17.         put("signed", new String[]{"end", "end", "in_number", "end"});
  18.         put("in_number", new String[]{"end", "end", "in_number", "end"});
  19.         put("end", new String[]{"end", "end", "end", "end"});
  20.     }};
  21.     public void get(char c) {
  22.         state = table.get(state)[get_col(c)];
  23.         if ("in_number".equals(state)) {
  24.             ans = ans * 10 + c - '0';
  25.             ans = sign == 1 ? Math.min(ans, (long) Integer.MAX_VALUE) : Math.min(ans, -(long) Integer.MIN_VALUE);
  26.         } else if ("signed".equals(state)) {
  27.             sign = c == '+' ? 1 : -1;
  28.         }
  29.     }
  30.     private int get_col(char c) {
  31.         if (c == ' ') {
  32.             return 0;
  33.         }
  34.         if (c == '+' || c == '-') {
  35.             return 1;
  36.         }
  37.         if (Character.isDigit(c)) {
  38.             return 2;
  39.         }
  40.         return 3;
  41.     }
  42. }
复制代码
 思绪剖析

1. 类 Solution

方法 myAtoi



  • 功能:将字符串转换为整数。
  • 参数:str,表现输入的字符串。
  • 返回值:转换后的整数。
该方法首先创建一个 Automaton 对象,然后遍历字符串中的每个字符,调用 Automaton 对象的 get 方法举行处理。末了返回颠末处理的整数结果。
2. 类 Automaton

成员变量



  • sign:表现正负号,默以为 1(正数)。
  • ans:存储转换后的整数结果。
  • state:表现当前状态,初始为 “start”。
  • table:状态转移表,用于根据当前状态和字符范例确定下一个状态。
方法 get



  • 功能:根据当前字符和状态,更新状态并处理整数转换。
  • 参数:c,表现当前处理的字符。
该方法首先根据当前状态和字符范例,从状态转移表中获取下一个状态。然后根据下一个状态实行相应的利用:


  • 假如状态为 “in_number”,则将当前字符转换为整数并累加到 ans 中。同时,查抄 ans 是否超出整数范围,并举行截断处理。
  • 假如状态为 “signed”,则根据字符是 ‘+’ 还是 ‘-’ 设置 sign 的值。
方法 get_col



  • 功能:根据字符范例返回对应的列索引。
  • 参数:c,表现当前处理的字符。
  • 返回值:列索引,用于在状态转移表中查找下一个状态。
该方法根据字符范例返回对应的列索引:


  • 空格:返回 0
  • 正负号:返回 1
  • 数字:返回 2
  • 其他字符:返回 3
代码实行流程


  • 创建 Automaton 对象,初始化状态为 “start”。
  • 遍历输入字符串中的每个字符。
  • 调用 Automaton 对象的 get 方法,根据当前字符和状态举行状态转移。
  • 在状态转移过程中,假如碰到数字,则累加到 ans 中,并处理整数范围溢出。
  • 假如碰到正负号,则设置 sign 的值。
  • 遍历竣事后,根据 sign 和 ans 计算最闭幕果并返回。
知识点精炼


  • 字符串处理:掌握字符串的根本利用,如遍历和字符范例判断。
  • 有限状态机:理解状态机的概念,能够根据不同输入举行状态转移。
  • 符号识别:能够处理正负号,并影响最闭幕果的符号。
  • 整数累加与范围控制:在累加过程中注意整数范例的范围限制,防止溢出。
  • 映射表应用:利用哈希表实现状态转移逻辑,进步代码的可读性和服从


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

曹旭辉

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表