三天一题-18- 字符串转换整数 (atoi)

题目地址:字符串转换整数 (atoi)

描述:
给定一个字符串,依次读取,当首个非空字符为“-”或者数字的时候,进行读取连续的数字;当数字大于Integer最大值时返回最大值;当数字小于最小值时返回最小值;否则返回0;

Example 1:
输入: " -42"
输出: "-42"
Example 2:
输入: "4193 with words"
输出: 4193
Example 3:
输入: "words and 987"
输出: 0
解释: 第一个非空字符是 'w', 但它不是数字或正、负号。 因此无法执行有效的转换。

import java.util.regex.Pattern;

public class MyAtoi {
    public static void main(String[] args) {
        String str = "sss1212";
        String str1 = " -12278878 sfjfl";
        String str2 = "  222yyy";
        int i = myAtoi(str2);
        System.out.println(i);

    }

    public static int myAtoi(String str) {
        StringBuffer res = new StringBuffer();
        for (int i = 0; i < str.length(); i++) {
            char cr = str.charAt(i);
            //数字正则判断
            Pattern pattern = Pattern.compile("^[\\+\\-\\d]\\d*");
            //空格字符串判断
            Pattern emptyPattern = Pattern.compile("\\s+");
            if (emptyPattern.matcher(cr + "").matches()) continue;
            if (!pattern.matcher(cr + "").matches()) {
                if (res.length() == 0) {
                    return 0;
                }
                break;
            }
            res.append(cr);
        }
        if (Long.parseLong(res.toString()) > Integer.MAX_VALUE)
            return Integer.MAX_VALUE;
        if (Long.parseLong(res.toString()) < Integer.MIN_VALUE)
            return Integer.MIN_VALUE;
        return Integer.parseInt(res.toString());
    }
}

``


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值