菜鸟笔记
提升您的技术认知

剑指offer

《剑指offer》刷题目笔记

剑指offer 数组

《剑指offer》二维数组中的查找《剑指offer》旋转数组的最小数字《剑指offer》调整数组顺序使奇数位于偶数前面《剑指offer》数组中出现次数超过一半的数字《剑指offer》连续子数组的最大和《剑指offer》把数组排成最小的数《剑指offer》数组中的逆序对《剑指offer》数字在排序数组中出现的次数《剑指offer》数组中只出现一次的数字《剑指offer》数组中重复的数字《剑指offer》构建乘积数组

剑指offer 字符串

《剑指offer》替换空格《剑指offer》字符串的排列《剑指offer》第一个只出现一次的字符《剑指offer》左旋转字符串《剑指offer》翻转单词顺序序列《剑指offer》把字符串转换成整数《剑指offer》正则表达式匹配《剑指offer》表示数值的字符串

剑指offer 链表

《剑指offer》从尾到头打印链表《剑指offer》链表中倒数第k个结点《剑指offer》反转链表《剑指offer》合并两个排序的链表《剑指offer》复杂链表的复制《剑指offer》两个链表的第一个公共结点《剑指offer》链表中环的入口结点《剑指offer》删除链表中重复的结点

剑指offer 树

《剑指offer》重建二叉树《剑指offer》树的子结构《剑指offer》二叉树的镜像《剑指offer》从上往下打印二叉树《剑指offer》二叉树中和为某一值的路径《剑指offer》二叉树的深度《剑指offer》平衡二叉树《剑指offer》二叉树的下一个结点《剑指offer》对称的二叉树《剑指offer》按之字顺序打印二叉树《剑指offer》把二叉树打印成多行《剑指offer》序列化二叉树

《剑指offer》表示数值的字符串-ag真人游戏

阅读 : 115

题目描述

请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串" 100","5e2","-123","3.1416"和"-1e-16"都表示数值。 但是"12e","1a3.14","1.2.3"," -5"和"12e 4.3"都不是。

解题思路

这道题还是比较简单的。表示数值的字符串遵循如下模式:

[sign]integral-digits[.[fractional-digits]][e|e[sign]exponential-digits]

其中,('['和']'之间的为可有可无的部分)。

在数值之前可能有一个表示正负的' '或者'-'。接下来是若干个0到9的数位表示数值的整数部分(在某些小数里可能没有数值的整数部分)。如果数值是一个小数,那么在小数后面可能会有若干个0到9的数位表示数值的小数部分。如果数值用科学记数法表示,接下来是一个'e'或者'e',以及紧跟着的一个整数(可以有正负号)表示指数。

判断一个字符串是否符合上述模式时,首先看第一个字符是不是正负号。如果是,在字符串上移动一个字符,继续扫描剩余的字符串中0到9的数位。如果是一个小数,则将遇到小数点。另外,如果是用科学记数法表示的数值,在整数或者小数的后面还有可能遇到'e'或者'e'。

代码实现(c )

class solution {
public:
    // 数字的格式可以用a[.[b]][e|ec]或者.b[e|ec]表示,
    // 其中a和c都是整数(可以有正负号,也可以没有)
    // 而b是一个无符号整数
    bool isnumeric(char* string)
    {
        // 非法输入处理
        if(string == null || *string == '\0'){
            return false;
        }
        // 正负号判断
        if(*string == ' ' || *string == '-'){
              string;
        }
        bool numeric = true;
        scandigits(&string);
        if(*string != '\0'){
            // 小数判断
            if(*string == '.'){
                  string;
                scandigits(&string);
                if(*string == 'e' || *string == 'e'){
                    numeric = isexponential(&string);
                }
            }
            // 整数判断
            else if(*string == 'e' || *string == 'e'){
                numeric = isexponential(&string);
            }
            else{
                numeric = false;
            }
        }
        return numeric && *string == '\0';
    }
private:
    // 扫描数字,对于合法数字,直接跳过
    void scandigits(char** string){
        while(**string != '\0' && **string >= '0' && **string <= '9'){
              (*string);
        }
    }
    // 用来潘达un科学计数法表示的数值的结尾部分是否合法
    bool isexponential(char** string){
          (*string);
        if(**string == ' ' || **string == '-'){
              (*string);
        }
        if(**string == '\0'){
            return false;
        }
        scandigits(string);
        // 判断是否结尾,如果没有结尾,说明还有其他非法字符串
        return (**string == '\0') ? true : false;
    }
};
网站地图