您的位置:首页 > 编程语言 > Java开发

[leetcode-8]String to Integer (atoi)(java)

2015-07-23 20:40 417 查看
问题描述:

Implement atoi to convert a string to an integer.

Hint: Carefully consider all possible input cases. If you want a challenge, please do not see below and ask yourself what are the possible input cases.

Notes: It is intended for this problem to be specified vaguely (ie, no given input specs). You are responsible to gather all the input requirements up front.

分析:首先,先对字符串进行一次过滤,将开头的空格去掉。然后在查找之后的,当遇到+-时后面一定要求是数字,也即不能是++或者+-或者-+或者–等情况。此外,更重要的一点是注意溢出现象。特别的当sum*10时发生溢出不好判断,因此,我设置了sum的阈值。当sum>这个阈值时,肯定会发生溢出。此时,再单独处理。

代码如下:404ms

[code]    public int myAtoi(String str) {
        char tmp;
        int sum = 0;
        int i;
        boolean minus = false;
        boolean requireNumber = false;
        boolean overflow = false;
        //clear the space
        for(i = 0;i<str.length();i++){
            if((tmp=str.charAt(i))!=' ')
                break;
        }   
        for(;i<str.length();i++){
            if((tmp=str.charAt(i))=='+'){
                if(requireNumber)
                    break;
                requireNumber = true;
            }
            else if(tmp=='-'){
                if(requireNumber)
                    break;
                requireNumber = true;
                minus = true;
            }
            else if(tmp>='0'&&tmp<='9'){
                if(sum>Integer.MAX_VALUE/10){
                    sum = -1;
                }else
                    sum = sum*10+tmp-'0';
                if(sum<0){
                    sum = Integer.MAX_VALUE;
                    overflow = true;
                }
            }else {
                break;
            }
        }
        if(overflow&&minus)
            return sum+1;
        else if(overflow)
            return sum;
        return minus?-sum:sum;
    }
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: