• 【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;
        }
    };
     
  • 相关阅读:
    性能测试相关名词
    Java中的并发工具类:CountDownLatch、CyclicBarrier和Semaphore
    spring与mybatis五种整合方法
    Powerdesigner使用技巧
    基于Redis的Spring cache 缓存介绍
    AspectJ AOP介绍
    Spring AOP的实现原理
    -webkit-tap-highlight-color
    Zero Clipboard js+swf实现的复制功能使用方法
    CSS3 RGBA 属性高级用法
  • 原文地址:https://www.cnblogs.com/wikiwen/p/10224821.html
Copyright © 2020-2023  润新知