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;

    }
};
相关推荐
Wang ruoxi8 小时前
基于最小二乘法的离散数据拟合
人工智能·算法·机器学习
Xの哲學8 小时前
Linux链路聚合深度解析: 从概念到内核实现
linux·服务器·算法·架构·边缘计算
加成BUFF8 小时前
C++入门讲解3:数组与指针全面详解
开发语言·c++·算法·指针·数组
代码游侠8 小时前
应用——管道与文件描述符
linux·服务器·c语言·学习·算法
一招定胜负8 小时前
决策树开篇
算法·决策树·机器学习
GoWjw8 小时前
C语言高级特性
c语言·开发语言·算法
carver w8 小时前
说人话版 K-means 解析
算法·机器学习·kmeans
小O的算法实验室9 小时前
2026年SEVC SCI2区,基于差分向量内学习策略的自适应指数交叉差分进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
gloomyfish9 小时前
【最新技术】多模态零样本工业缺陷检测概述
人工智能·算法·计算机视觉
渡过晚枫9 小时前
[蓝桥杯/java/算法]攻击次数
java·算法·蓝桥杯