leetCode65. 有效数字

leetCode65. 有效数字

题目思路


代码

cpp 复制代码
class Solution {
public:
    bool isNumber(string s) {
        int l = 0, r = s.size() - 1;
        // 1.忽略前后的空格
        while(l <= r && s[l] == ' ') l++;
        while(l <= r && s[r] == ' ') r--;
        if(l > r) return false;
        s = s.substr(l,r - l + 1); // 区间左闭右开

        // 2.判断其实是否为符号
        if(s[0] == '+' || s[0] == '-') s = s.substr(1);// s = 提取到[1,end)
        if(s.empty()) return false;

        // 3.  (.e或者只有.)是错误的
        if(s[0] == '.' && (s.size() == 1 || s[1] == 'e' || s[1] == 'E')) return false;

        // e后面必必须是整数,且不能什么都没有
        int dot = 0, e = 0; // .个数于e个数
        for(int i = 0; i < s.size(); i++){
            if(s[i] == '.'){
                // .个数大于1,或者.出现在e后面
                if(dot > 0 || e > 0) return false;
                dot++;
            }else if(s[i] == 'e' || s[i] == 'E'){
                // e的前后不能什么都没有,e只能出现一次
                if(!i || i + 1 == s.size() || e > 0) return false;
                // e后面跟符号,符号后不能什么都没有
                if(s[i + 1] == '+' || s[i + 1] == '-'){
                    if(i + 2 == s.size()) return false;
                    i++; // 不要在判断符号了
                }

                e++;
            }else if(s[i] < '0' || s[i] > '9') return false;
        }

        return true;
    }
};
相关推荐
一起养小猫7 小时前
LeetCode100天Day14-轮转数组与买卖股票最佳时机
算法·leetcode·职场和发展
程序员-King.9 小时前
day143—递归—对称二叉树(LeetCode-101)
数据结构·算法·leetcode·二叉树·递归
Ethan-D11 小时前
#每日一题19 回溯 + 全排列思想
java·开发语言·python·算法·leetcode
橘颂TA12 小时前
【剑斩OFFER】算法的暴力美学——LeetCode 733 题:图像渲染
算法·leetcode·职场和发展
FMRbpm14 小时前
树的练习6--------938.二叉搜索树的范围和
数据结构·c++·算法·leetcode·职场和发展·新手入门
多米Domi01114 小时前
0x3f 第35天 电脑硬盘坏了 +二叉树直径,将有序数组转换为二叉搜索树
java·数据结构·python·算法·leetcode·链表
想逃离铁厂的老铁14 小时前
Day45 >> 115、不同的子序列 + 583. 两个字符串的删除操作 + 72. 编辑距离
算法·leetcode
程序员-King.15 小时前
day144—递归—平衡二叉树(LeetCode-110)
算法·leetcode·二叉树·递归
老鼠只爱大米15 小时前
LeetCode经典算法面试题 #739:每日温度(单调栈、动态规划等多种实现方案详解)
算法·leetcode·面试·动态规划·单调栈·每日温度
老鼠只爱大米15 小时前
LeetCode经典算法面试题 #394:字符串解码(递归、双栈、迭代构建等五种实现方案详解)
算法·leetcode·面试·递归··字符串解码