算法第七周作业01

Description

Validate if a given string is numeric.
Some examples:
“0” => true
” 0.1 ” => true
“abc” => false
“1 a” => false
“2e10” => true
Note: It is intended for the problem statement to be ambiguous. You should gather all requirements up front before implementing one.

Solution

  • 采用模拟法,考虑所有可能情况
  • 考虑当出现特殊字符’e’(指数类型)时,其左边是数值(包括小数),右边也是数值(无小数点)
  • 通过字符长度排除”.”, “+.”等情况,通过’e’出现位置排除”1e1e”,”e1e1”等情况,通过point, sign 排除重复出现’.’, ‘+’等情况

Code

    // 是否出现了小数点
    boolean point = false;
    public boolean isNumber(String s) {
        // 去除空格
        s = s.trim();
        // 将e左右分离
        String[] split = s.split("e");
        if (split.length == 1 && !s.contains("e")) {
            // 不是指数类型,排除"e","e1","1e"等情况
            return isInvalidate(split[0], true);
        } else if (split.length == 2 && !s.startsWith("e") && !s.endsWith("e")) {
            // 是指数类型,排除"1e1e","e1e1"等情况
            return isInvalidate(split[0], true) && isInvalidate(split[1], false);
        }
        return false;
    }
    //left=true表示s是'e'的左边数值(或者非指数类型),left=false表示s是指数部分
    private boolean isInvalidate(String s, boolean left) {
        // 是否出现了正负符号
        boolean sign = false;
        char c;
        if(s.length() == 0)return false;
        for(int i=0; i<s.length(); i++){
            c = s.charAt(i);
            if(left && c == '.' && point == false && (s.length() > 2 || s.length() > 1 && !sign)){
                // 指数部分无小数点,排除".","..","+."等情况
                point = true;
            } else if(i == 0 && (c == '+' || c == '-') && s.length() > 1){
                // 左边数值和指数部分均可出现正负符号,排除"+","-"等情况
                sign = true;
            } else if(c < '0' || c > '9'){
                // 非以上字符的均为非法
                return false;
            }
        }
        return true;
    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值