剑指offer 把字符串转换成整数

题目描述

将一个字符串转换成一个整数(实现Integer.valueOf(string)的功能,但是string不符合数字要求时返回0),要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0。

输入描述:

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

输出描述:

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

示例1

输入

+2147483647
    1a33

输出

2147483647
    0

这是一道非常经典的题目,实现atoi函数

class Solution {
public:
    int StrToInt(string str) {
        int i=0;
        // 去掉前面的空格
        while(i<str.size() && str[i]==' ') i++;
        if(i==str.size()) return 0;
        bool flag = true;
        int sign = 1;
        int res = 0;
        if(str[i]=='-'){
            sign = -1;
            i++;
        }
        else if(str[i]=='+') i++;
        while(i<str.size()){
            if(isdigit(str[i])){
                res*=10;
                res += str[i]-'0';
                i++;
            }
            else{
                flag = false;
                break;
            }
        }
        if(flag) return sign*res;
        else return 0;
        
    }
};

猜你喜欢

转载自blog.csdn.net/wwxy1995/article/details/90082424