把字符串转换成整数

2020-04-27  本文已影响0人  李伟13

题目描述

将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0

输入描述:

输入一个字符串,包括数字字母符号,可以为空

输出描述:

如果是合法的数值表达则返回该数字,否则返回0

示例

输入

+2147483647
1a33

输出

2147483647
0

第一想法

没能AC的代码

class Solution {
public:
    int StrToInt(string str) {
        if(str.size() == 0)
            return 0;
        int i = 0;
        stack<int> st;
        int slogan = 1;
        if(str[i] == '+'){
            slogan = 1;
            i++;
        }
        if(str[i] == '-'){
            slogan = -1;
            i++;
        }
        while(str[i] != '\0'){
            if(str[i] < '0' || str[i] > '9')
                return 0;
            switch(str[i]){
                case '0':
                    st.push(0);
                    break;
                case '1':
                    st.push(1);
                    break;
                case '2':
                    st.push(2);
                    break;
                case '3':
                    st.push(3);
                    break;
                case '4':
                    st.push(4);
                    break;
                case '5':
                    st.push(5);
                    break;
                case '6':
                    st.push(6);
                    break;
                case '7':
                    st.push(7);
                    break;
                case '8':
                    st.push(8);
                    break;
                case '9':
                    st.push(9);
                    break;
            }
            i++;
        }
        int b = 0;
        long long num = 0;
        while(!st.empty()){
            num = st.top() * pow(10, b) + num;
            st.pop();
            b++;
        }
        num *= slogan;
        if(num > 2147483647 || num < -2147483648)
            return 0;
        return num;
    }
};

不能通过的原因是
用例:
-2147483649
对应输出应该为:
-2147483649
我就很疑惑,你的返回值要求是int类型,告诉我需要返回-2147483649???这让我怎么AC???

代码改进

class Solution {
public:
    int StrToInt(string str) {
        int len = str.size();
        if(len == 0)
            return 0;
        stack<int> st;
        int slogan = 1;
        int b = 0;
        long long num = 0;
        for(int i = len - 1; i >= 0; --i){
            if(i == 0 && str[0] == '+'){
                slogan = 1;
                break;
            }
            if(i == 0 && str[0] == '-'){
                slogan = -1;
                break;
            }
            if((str[i] < '0' || str[i] > '9' )&& i != 0)
                return 0;
            num = (str[i] - '0') * pow(10, b) + num;
            b++;
        }
        num *= slogan;
        if(num > 2147483647 || num < -2147483648)
            return 0;
        return num;
    }
};

舍去了switch和stack部分

知识点

上一篇 下一篇

猜你喜欢

热点阅读