zoukankan      html  css  js  c++  java
  • String to Integer (atoi)

    原文:http://www.cnblogs.com/zsboy/p/3886677.html

    问题:将字符窜转换成数字
    分析:感觉题目不难,但是细节很多,容易想不到
    1.数字前面有空格 如s=“    123456”
    2.数字前出现了不必要或多于的字符导致数字认证错误,输出0   如s=“   b1234”  ,s=“  ++1233” , s=“ +-1121”
    3.数字中出现了不必要的字符,返回字符前的数字 如s=“   12a12” , s=“ 123  123”
    4.数字越界 超过了范围(-2147483648--2147483647) 若超过了负数的 输出-2147483648  超过了正数的输出2147483647
    在科普一个知识点,倘若某个数超过了2147483647则会变为负数,反过来一样

     

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    class Solution {
    public:
        int atoi(const char *str) {
        long long cur=0;//初始化老是忘记
        int num=0,i=0;
        int flag1=0,flag2=0;
        while(str[i]!='' && str[i]==' ') i++;//开头空格舍弃
        if(str[i]=='-') flag1++,i++;
        else if(str[i]=='+') flag2++,i++;
        for(; str[i]!=''; i++)
        {
            if(str[i]>='0' && str[i]<='9')
            {
                if(flag1==2)
                {
                    cur=cur*10-(str[i]-'0');//这里是减法,因为cur符号是负号了
                    if(cur<-2147483648) return -2147483648;
                }
                else if(flag1==1) cur=-str[i]+'0',flag1++;//将负数的符号记录到cur里
                else
                {
                    cur=cur*10+(str[i]-'0');
                    if(cur>2147483647) return 2147483647;
                }
            }
            else break;
        }
        num=(int)cur;
        return num;
        }
    };
  • 相关阅读:
    BUCK/BOOST电路原理分析
    boost升压电路原理
    NPN/PNP和N沟道/P沟道负载的接法
    常用电源芯片记录
    LDO和BUCK降压稳压器对比
    some nets were not able to be matched
    Altium PCB布局时快速摆放元件的技巧
    树莓派+android things+实时音视频传输demo之遥控小车
    野狗产品与价格
    librtmp将本地FLV文件发布到RTMP流媒体服务器
  • 原文地址:https://www.cnblogs.com/lizhigang/p/7199711.html
Copyright © 2011-2022 走看看