剑指 Offer JZ49 把字符串转换成整数

Posted 程序字母K

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了剑指 Offer JZ49 把字符串转换成整数相关的知识,希望对你有一定的参考价值。

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

思路:遍历查找非整数字符,第一个字符串位置进行判断,
采用-‘0’算出整数*10的多少次方;
最后判断是否为负数;

class Solution {
public:
    int StrToInt(string str) {
        int flag=0,_size=str.size()-1;
        long int sum=0;
        for(int i=0;i<str.size();i++){
            if(str[0]=='+')
                flag=1;
            else if(str[0]=='-')
                flag=-1;
             if(i==0&&(str[i]=='+'||str[i]=='-')) {
                 _size--;
                 continue;
                                                  }
            if(str[i]>'9'||str[i]<'0')
                return 0;
                sum+=(str[i]-'0')*pow(10,_size);
                _size--;
            
        }
        if(flag==-1)
            sum=(-1)*sum;
        return sum;
    }
};

以上是关于剑指 Offer JZ49 把字符串转换成整数的主要内容,如果未能解决你的问题,请参考以下文章

《剑指offer》JZ41 ~ JZ50

《剑指offer》JZ41 ~ JZ50

《剑指offer》JZ41 ~ JZ50

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

[剑指offer] 49. 把字符串转换成整数

剑指offer 49.综合 把字符串转换成整数