String to Integer (atoi)

class Solution {
public:
    int myAtoi(string str) {
        
    	long long int  result = 0;//注意,为了判断溢出,要定义为long long int
    	int PositiveFlag = 1;
    	int i = 0;
    	if(str.size() == 0)
    		return 0;
    
    	while(i < str.size() && str[i] == ' ')//去除其那面所有空格
    		i++;
    
    	if(str[i] == '-' || str[i] == '+')//正负判断
    	{
    		PositiveFlag = (str[i] == '-')?-1:1;
    		i++;
    	}
    
    	while(i < str.size() )
    	{
    		if(str[i] >= '0' && str[i] <= '9')
    		{	
    			result*=10;
    			result += (str[i] - '0');
    			if(result > INT_MAX || result < INT_MIN)//overflow
    			    return (PositiveFlag == 1)?INT_MAX:INT_MIN;
    		}
    		else //未知字符
    			break;
    		i++;
    	}
    	
    	return result * PositiveFlag;
    }
};

阅读更多
个人分类: LeetCode
上一篇LeetCode || 未完成的题目
下一篇Remove Nth Node From End of List
想对作者说点什么? 我来说一句

没有更多推荐了,返回首页

关闭
关闭