题目
请你来实现一个 atoi 函数,使其能将字符串转换成整数。
首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止。
当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号;假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数。
该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响。
注意:假如该字符串中的第一个非空格字符不是一个有效整数字符、字符串为空或字符串仅包含空白字符时,则你的函数不需要进行转换。
在任何情况下,若函数不能进行有效的转换时,请返回 0。
说明:
假设我们的环境只能存储 32 位大小的有符号整数,那么其数值范围为 [−231, 231 − 1]。如果数值超过这个范围,请返回 INT_MAX (231 − 1) 或 INT_MIN (−231) 。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/string-to-integer-atoi
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
解答
class Solution {public int myAtoi(String str) {if (str == null) {return 0;}String value = str.trim();if (value.isEmpty()) {return 0;}java.util.regex.Pattern pattern = java.util.regex.Pattern.compile("^([\\+\\-]?)(\\d{1,})");java.util.regex.Matcher matcher = pattern.matcher(value);if (!matcher.find()) {return 0;}String flag = matcher.group(1);String decimal = matcher.group(2);try {long lValue = Long.parseLong(flag + decimal);if ("".equals(flag) || "+".equals(flag)) {if (lValue > Integer.MAX_VALUE) {return Integer.MAX_VALUE;} }if ("-".equals(flag)) {if (lValue < Integer.MIN_VALUE) {return Integer.MIN_VALUE;}}} catch (NumberFormatException e) {e.printStackTrace();if ("".equals(flag) || "+".equals(flag)) {return Integer.MAX_VALUE;}if ("-".equals(flag)) {return Integer.MIN_VALUE;}}try {return Integer.parseInt(flag + decimal);} catch (NumberFormatException e) {e.printStackTrace();}return 0;}
}
要点
作为Java程序员,有现成的方法当然要使用。
正则表达式有助于提取数字,假如不满足要求,则直接判定为0。
本题的难度在于,数字可能很大,超出Integer和Long的表达范围,因此在对数字的表达范围进行检查时,需要增加特别的操作。
前述实现并不优雅,后续需要设计更优雅的方案。
准备的用例,如下
@Testpublic void test01() {assertEquals(42, new L8().myAtoi("42"));assertEquals(42, new L8().myAtoi("+42"));assertEquals(-42, new L8().myAtoi("-42"));assertEquals(-42, new L8().myAtoi(" -42"));assertEquals(4193, new L8().myAtoi("4193 with words"));assertEquals(0, new L8().myAtoi("words and 987"));assertEquals(0, new L8().myAtoi(" "));assertEquals(0, new L8().myAtoi(""));assertEquals(-2147483648, new L8().myAtoi("-91283472332"));assertEquals(2147483647, new L8().myAtoi("91283472332"));assertEquals(Integer.MIN_VALUE, new L8().myAtoi(String.valueOf(Integer.MIN_VALUE)));assertEquals(Integer.MAX_VALUE, new L8().myAtoi(String.valueOf(Integer.MAX_VALUE)));assertEquals(Integer.MAX_VALUE, new L8().myAtoi("20000000000000000000"));assertEquals(Integer.MIN_VALUE, new L8().myAtoi("-20000000000000000000"));}