面试题21-表示数值的字符串

题目要求

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

题目解析

思路一:

  • 分析

表示数值的字符串遵循模式A[.[B]][e|EC]或者.B[e|EC]
其中A表示整数部分,B表示小数部分,C表示指数部分。

  • 代码段
    public static boolean isNum(String text ) {
        
        char[] data = null ;
        int index = 0 ;
        if(text == null || text.length() == 0) {
            return false ;
        }
        
        data = text.toCharArray() ;
        
        //是否有符号位存在,存在则跳过
        if(data[0] == '+' || data[0] == '-') {
            index ++ ;
        }
        
        //解析A部分是否正确
        while( index < data.length) {
            
            //查看是否“.”,如果是直接跳出。
            if(data[index] == '.') {
                index++ ;
                break ;
            }
            
            //查看是否“e|E”,如果是直接跳出,不移动下标在B部分进行处理。
            if(data[index] == 'e' || data[index] == 'E') {
                break ;
            }
            
            if(data[index] >= '0' && data[index] <= '9') {
                index++ ;
                continue ;
            }
            
            return false ;
            
        }
        
        //解析B部分是否正确 
        while( index < data.length) {
            
            //查看是否“e|E”,如果是直接跳出。
            if(data[index] == 'e' || data[index] == 'E') {
                index++ ;
                break ;
            }
            
            if(data[index] >= '0' && data[index] <= '9') {
                index++ ;
                continue ;
            }
            
            return false ;
        }
        
        //查看c部分有没有正负号,如果有跳过
        if(index < data.length && (data[index] == '+' || data[index] == '-')) {
            index ++ ;
        }
        
        //解析C部分是否正确
        while( index < data.length) {
            
            if(data[index] >= '0' && data[index] <= '9') {
                index++ ;
                continue ;
            }
            
            return false ;
        }
        
        return true ;
    }

测试代码

    public static void main(String[] args) {
        
        String text1 = "+100" ;
        String text2 = "5e2" ;
        String text3 = "-1E-16" ;
        String text4 = "3.1416" ;
        String text5 = "1a3.14" ;
        String text6 = "+-5" ;
        String text7 = "1a3.14" ;
        
        System.out.println(isNum(text1));
        System.out.println(isNum(text2));
        System.out.println(isNum(text3));
        System.out.println(isNum(text4));
        System.out.println(isNum(text5));
        System.out.println(isNum(text6));
        System.out.println(isNum(text7));
        
    }
    

运行结果

true
true
true
true
false
false
false


看完整源码戳源码地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,930评论 18 399
  • 《ilua》速成开发手册3.0 官方用户交流:iApp开发交流(1) 239547050iApp开发交流(2) 1...
    叶染柒丶阅读 13,783评论 0 11
  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 8,456评论 0 4
  • 本学期参与了信息组织与检索课程的学习,并通过一次次练习掌握了信息检索的各项技能。目录1.信息检索读物读后感.......
    苏聪不是酥葱阅读 4,296评论 0 1
  • 目前宝宝1岁零12天正是好动的时候,而我已经怀二宝4个半月。并且准备二宝出生之前把驾驶证考到手。 随着月份越来越大...
    夏花依在阅读 1,488评论 0 2