8-中等-字符串转换整数 (自动机)[C语言]

在这里插入图片描述

enum{
    Start = 0,
    Sign,
    In_num,
    End
};

int get_col(char c) {
    if (c == ' ') return 0;
    if (c == '+' || c == '-') return 1;
    if ('0' <= c && c <= '9') return 2;
    return 3;
}

const int table[4][4]={\
    {Start,Sign,In_num,End},\
    {End,End,In_num,End},\
    {End,End,In_num,End},\
    {End,End,End,End}\
};

int myAtoi(char * s){
    int ans = 0;
    int sign = 1;
    int state = Start;

    while('\0' != *s){
        state = table[state][get_col(*s)];
        if(In_num == state){
            int temp = (*s) - '0';
            if(ans > INT_MAX/10 || (ans == INT_MAX/10 && temp > 7))
                return sign==1?INT_MAX:INT_MIN;
            ans = ans*10 + temp;
        } else if(Sign == state){
            if('-' == *s)
                sign = -1;
        } else if(End == state)
            break;
        s++;
    }
    return sign==1?ans:-ans;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值