美文网首页
把字符串转换成整数

把字符串转换成整数

作者: 李伟13 | 来源:发表于2020-04-27 15:39 被阅读0次

题目描述

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

输入描述:

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

输出描述:

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

示例

输入

+2147483647
1a33

输出

2147483647
0

第一想法

  • 将字符串放入栈中.
  • 出栈,看是否是数字,不是直接返回0
  • 使用long long看是否超出范围,超范围返回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部分

知识点

  • 转换char字母和数字,只需要'1' - '0',即减去字符0

相关文章

  • 67:把字符串转换成整数

    题目67:把字符串转换成整数 实现一个函数stringToInt,实现把字符串转换成整数这个功能,不能使用atoi...

  • 把字符串转换成整数-java

    把字符串转换成整数 题目描述 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串...

  • JZ-049-把字符串转换成整数

    把字符串转换成整数 题目描述 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串...

  • 字符串转换成整数

    字符串转换成整数 题目描述: 输入一个由数字组成的字符串,把它转换成整数并输出。例如:输入字符串"123",输出整...

  • 剑指offer(四十九)把字符串转换成整数

    点击进入 牛客网题库:把字符串转换成整数 题目描述将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。...

  • 剑指 offer:49、把字符串转化成整数

    49. 把字符串转换成整数 题目描述 将一个字符串转换成一个整数(实现Integer.valueOf(string...

  • 数据转换

    1.int(x[,base])(1)把符合数学格式的数字型字符串转换成整数;(2)把浮点数转换成整数,但是只是简单...

  • python 数据类型转换

    强制类型转换 int 函数 把符合数学格式的数字型字符串转换成整数 把浮点数转换成整数,但是只是简单的取整,而非四...

  • 字符串系列--字符转整型数

    1. 字符转整型数 输入一个由数字组成的字符串,把它转换成整数并输出。例如:输入字符串"123",输出整数123。...

  • 三、Java中级--2、错误处理的两个例子

    1、字符串转换成整数 对字符串“hello”转换成整数时,会报错,但是如果将s定义为“100”,在转换时就不会出错...

网友评论

      本文标题:把字符串转换成整数

      本文链接:https://www.haomeiwen.com/subject/tliywhtx.html