leetcode 8 字符串转整数

class Solution {
public:
    int myAtoi(string str) {
        int sign=0;
        int firstNonSpace;
        int lastNonSpace;

        for(firstNonSpace=0;firstNonSpace<str.size();firstNonSpace++){
            if(str[firstNonSpace]!=‘ ‘){
                break;
            }
        }
        if(firstNonSpace==str.size()){
            return 0;
        }
        else{
            if(str[firstNonSpace]==‘+‘){
                firstNonSpace++;
            }
            else if(str[firstNonSpace]==‘-‘){
                sign=1;
                firstNonSpace++;
            }
            if(firstNonSpace==str.size()){
                return 0;
            }
            if((str[firstNonSpace]<‘0‘)||(str[firstNonSpace]>‘9‘)){
               return 0;
            }

            for(lastNonSpace=firstNonSpace;lastNonSpace<str.size();){
                if((str[lastNonSpace]>=‘0‘)&&(str[lastNonSpace]<=‘9‘)){
                    lastNonSpace++;
                }
                else{
                    break;
                }
            }
            if(lastNonSpace-firstNonSpace>10){
                if(sign==0){
                    return INT_MAX;
                }
                else{
                    return INT_MIN;
                }
            }
            if(lastNonSpace-firstNonSpace==10){
                if(sign==0&&str.substr(firstNonSpace,lastNonSpace-firstNonSpace)>="2147483647"){
                    return INT_MAX;
                }
                else if(sign==1&&str.substr(firstNonSpace,lastNonSpace-firstNonSpace)>="2147483648"){
                    return INT_MIN;
                }
            }
            int result=0;
                for(int i=firstNonSpace;i<lastNonSpace;i++){
                    result=(str[i]-‘0‘)+result*10;
                }
                if(sign==0){
                    return result;
                }
            else{
                return -result;
            }
        }
    }
};

击败30%。

然后我今天又交了一次,没过。

" 0000000000012345678"

别人的代码:

class Solution {
public:
    int myAtoi(string str) {
        if (str.empty()) return 0;
        int sign = 1, base = 0, i = 0, n = str.size();
        while (i < n && str[i] == ‘ ‘) ++i;
        if (str[i] == ‘+‘ || str[i] == ‘-‘) {
            sign = (str[i++] == ‘+‘) ? 1 : -1;
        }
        while (i < n && str[i] >= ‘0‘ && str[i] <= ‘9‘) {
            if (base > INT_MAX / 10 || (base == INT_MAX / 10 && str[i] - ‘0‘ > 7)) {
                return (sign == 1) ? INT_MAX : INT_MIN;
            }
            base = 10 * base + (str[i++] - ‘0‘);
        }
        return base * sign;
    }
};

来自:http://www.cnblogs.com/grandyang/p/4125537.html

原文地址:https://www.cnblogs.com/azureice/p/leetcode8.html

时间: 2024-11-26 14:51:23

leetcode 8 字符串转整数的相关文章

LeetCode 44.字符串转换整数 (atoi)

题目描述 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止.接下来的转化规则如下: 如果第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字字符组合起来,形成一个有符号整数.假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成一个整数.该字符串在有效的整数部分之后也可能会存在多余的字符,那么这些字符可以被忽略,它们对函数不应该造成影响.注意:假如该字符串中的第一个非空格字符不

LeetCode(8. 字符串转换整数 (atoi))

问题描述 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. 当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号:假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数. 该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响. 注意:假如该字符串中的第一个非空格字符不是一个有效整数字

leetcode——8. 字符串转换整数 (atoi)

看着挺简单,结果不断出错不断修改,就很容易绕晕了,用了一个小时四十分钟左右才完成...好慢哦: class Solution(object): def myAtoi(self, str): """ :type str: str :rtype: int """ a=str.lstrip() if len(a)<1: return 0 if len(a)==1: if a[0] not in '0123456789': return 0 els

leetcode - String to Integer (atoi) 字符串转整数

Implement atoi to convert a string to an integer. 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. 题目:实现字符串转整数 注意事项:考虑好各种可能的输入(坑); public class Solution

[LeetCode] 字符串转整数

字符串转换整数(atoi) 题目描述 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. 当我们寻找到的第一个非空字符为正或者负号时,则将该符号与之后面尽可能多的连续数字组合起来,作为该整数的正负号:假如第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数. 该字符串除了有效的整数部分之后也可能会存在多余的字符,这些字符可以被忽略,它们对于函数不应该造成影响. 注意:假如该字符串中的第一个

[LeetCode] String to Integer (atoi) 字符串转为整数

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 spe

LeetCode刷题-008字符串转为整数

实现 atoi,将字符串转为整数.在找到第一个非空字符之前,需要移除掉字符串中的空格字符.如果第一个非空字符是正号或负号,选取该符号,并将其与后面尽可能多的连续的数字组合起来,这部分字符即为整数的值.如果第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数.字符串可以在形成整数的字符后面包括多余的字符,这些字符可以被忽略,它们对于函数没有影响.当字符串中的第一个非空字符序列不是个有效的整数:或字符串为空:或字符串仅包含空白字符时,则不进行转换.若函数不能执行有效的转换,返回 0

leetcode 字符串转整数(atoi)

实现atoi,将字符串转为整数. 在找到第一个非空字符之前,需要移除掉字符串中的空格字符.如果第一个非空字符是正号或负号,选取该符号,并将其与后面尽可能多的连续的数字组合起来,这部分字符即为整数的值.如果第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数. 字符串可以在形成整数的字符后面包括多余的字符,这些字符可以被忽略,它们对于函数没有影响. 当字符串中的第一个非空字符序列不是个有效的整数:或字符串为空:或字符串仅包含空白字符时,则不进行转换. 若函数不能执行有效的转换,返

Leetcode篇:字符串转为整数

@author: ZZQ @software: PyCharm @file: myAtoi.py @time: 2018/9/20 20:54 要求:实现 atoi,将字符串转为整数. 1)根据需要丢弃任意多的空格字符,直到找到第一个非空格字符为止 2)如果第一个非空字符是正号或负号,选取该符号: 3) 将其与后面尽可能多的连续的数字组合起来,这部分字符即为整数的值. 4) 如果第一个非空字符是数字,则直接将其与之后连续的数字字符组合起来,形成整数. 5) 字符串可以在形成整数的字符后面包括多余