【LeetCode & 剑指offer刷题】字符串题6:67 把字符串转成整数

【LeetCode & 剑指offer 刷题笔记】目录(持续更新中...)

67 把字符串转成整数

题目描述

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

输入描述:

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

输出描述:

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

输入

复制
+2147483647
1a33

输出

复制
2147483647
0
 
 
/*
本题没有考虑前面有空格的情况,与leetcode中题目有点不同
而且把1a33这样的字符也当做异常,不会输出1
1. 处理正负号
2. 处理数字
3. 处理溢出
4. 处理夹杂异常字符的情况
*/
#include <climits>
class Solution
{
public:
    int StrToInt(string str)
    {
        if(str.empty()) return 0;//处理异常情况
       
        int sign = 1; //初始化符号
        int i = 0;
        if(str[i] == '-') //处理正负号
        {
            sign = -1;
            i++;
        }
        else if(str[i] == '+')
            i++;
       
        long long num = 0; //long long不管在32位机还是64位机中均为64位
        for(; i<str.size() && str[i] >= '0' && str[i] <= '9'; i++) //扫描数字
        {
            int digit = str[i] - '0';
            num = num*10 + digit;
            //处理溢出问题
            if( (sign > 0&& num > INT_MAX) || (sign<0 && -num < INT_MIN) )
            {
                num = 0;
                break;
            }
        }
       
        if(i < str.size()) num = 0; //说明是从中途退出,有异常字符
        return num*sign;
    }
};
 
原文地址:https://www.cnblogs.com/wikiwen/p/10224821.html