LeetCode 刷题【65. 有效数字】

65. 有效数字

自己做

解:逐个检查各位置

cpp 复制代码
class Solution {
public:
    bool isNumber(string s) {
        int begin = 0;                  //检查起始
        int int_len = 0;                //整数部分长度
        int float_len = 0;              //小数部分长度

        if(s[0] == '-' || s[0] == '+')  //符号位存在,整数部分起始位置调整为从1开始
            begin++;

        //检查整数位
        while(begin < (int)s.size() && s[begin] != '.' && s[begin] != 'e' && s[begin] != 'E'){
            if(s[begin] > '9' || s[begin] < '0')            //如果整数位出现了非数字,说明这不是一个正确的数字
                return false;
            begin++;
            int_len++;
        }

        //检查小数位(如果有)
        if(begin < (int)s.size() - 1 && s[begin] == '.'){
            begin++;                                            //小数位起始      

            while(begin < (int)s.size() && s[begin] != 'e' && s[begin] != 'E'){
                if(s[begin] > '9' || s[begin] < '0')            //如果小数位出现了非数字,说明这不是一个正确的数字
                    return false;
                begin++;
                float_len++;
            }            
        }

        if(int_len == 0 && float_len == 0)                      //如果整数部分和小数部分都为空,说明这不是一个正确的数字
            return false;

        //检查指数位(如果有)
        if(begin < (int)s.size() && (s[begin] == 'e' || s[begin] == 'E')){
            begin++;                                            //指数位起始

            if(begin == (int)s.size())                          //如果不存在指数位,说明这不是一个正确的数字=>排除"1e"的情况
                return false;

            if(s[begin] == '-' || s[begin] == '+')              //符号位存在,指数部分起始位置调整
                begin++;

            if(begin == (int)s.size())                          //如果不存在指数位,说明这不是一个正确的数字=>排除"1e+"的情况"
                return false;

            while(begin < (int)s.size()){
                if(s[begin] > '9' || s[begin] < '0')            //如果小数位出现了非数字,说明这不是一个正确的数字
                    return false;
                begin++;
            }            
        }

        return true;

    }
};
相关推荐
Klong.k2 小时前
判断是不是素数题目
数据结构·算法
QQsuccess2 小时前
AI全体系保姆级详讲——第一部分:了解AI基本定义
人工智能·算法
_日拱一卒2 小时前
LeetCode:移动零
算法·leetcode·职场和发展
A923A2 小时前
【洛谷刷题 | 第四天】
算法·前缀和·贪心·洛谷·差分
bai_lan_ya3 小时前
使用linux的io文件操作综合实验_处理表格
linux·服务器·算法
计算机安禾3 小时前
【C语言程序设计】第36篇:二进制文件的读写
c语言·开发语言·c++·算法·github·visual studio code·visual studio
ZPC82103 小时前
OLOv11 + 深度相机的方案实现高精度3D定位
人工智能·数码相机·算法·机器人
_日拱一卒3 小时前
LeetCode:字母异位词分组
算法·leetcode·职场和发展
Dfreedom.3 小时前
机器学习经典算法全景解析与演进脉络(监督学习篇)
人工智能·学习·算法·机器学习·监督学习
Zaly.3 小时前
【Python刷题】LeetCode 3567 子矩阵的最小绝对差
python·leetcode·矩阵