zoukankan      html  css  js  c++  java
  • 力扣题解 8th 字符串转换整数 (atoi)

    8th 字符串转换整数 (atoi)

    • 字符串模式匹配

      这种题目极易写出臃肿的代码,我们需要明确具体的条件,并充分考虑细节。(否则会被样例虐爆)

      这里有一个常用的判断溢出条件的方法,在之前的题目中也有出现。

      • 对于正数:

        if(number > Integer.MAX_VALUE / 10 || (number == Integer.MAX_VALUE / 10 && next_index > 7)) return "溢出";

      • 对于负数:

        if(number < Integer.MIN_VALUE / 10 || (number == Integer.MIN_VALUE / 10 && next_index < -8)) return "溢出";

      class Solution {
          public int myAtoi(String str) {
              if(str == null || str.length() == 0) return 0;
              int point = 0;
              boolean isPositive = true;
              int ans = 0;
      
              while (point < str.length() && str.charAt(point) == ' ') {
                  point++;
              }
      
              if (point < str.length() && str.charAt(point) == '+') {
                  point++;
              } else if (point < str.length() && str.charAt(point) == '-') {
                  isPositive = false;
                  point++;
              }
      
              while (point < str.length() && Character.isDigit(str.charAt(point))) {
                  if (ans > Integer.MAX_VALUE / 10 ||
                          (ans == Integer.MAX_VALUE / 10 && str.charAt(point) - '0' > 7)) {
                      return isPositive ? Integer.MAX_VALUE : Integer.MIN_VALUE;
                  }
      
                  ans = ans * 10 + str.charAt(point++) - '0';
              }
      
              return isPositive ? ans : -ans;
          }
      }
      
    • DFA有限状态机

  • 相关阅读:
    本周学习进度条2
    web—图表表示数据库中的数据
    Intern Day36
    计算机网络
    面试
    C++
    计算机网络
    腾讯PC客户端开发暑期实习一面
    TCP和UDP
    Intern Day34
  • 原文地址:https://www.cnblogs.com/fromneptune/p/13266743.html
Copyright © 2011-2022 走看看