剑指 Offer 20. 表示数值的字符串

Offer 20

常规解法:

  • 题目解题思路:需要注意几种情况:

    • 输入的字符串前后可能有任意多个空格,这是合法的。
    • 正负号:

      (1)正负号只能出现一次。

      (2)正负号后面一个字符必须是数字或者小数点。

      (3)字符串中最多有两个正负号(正常情况下最多只有一个,但是这里有指数E的情况,其前后可以加正负号)。
    • e或者E:

      (1) 指数符号最多出现一次。

      (2) 前一个字符必须是数字或者小数点,如果是小数点,则小数点不能出现在第一个字符的位置。

      (3) 后一个字符必须是数字或者正负号。

      (4) 后面的所有字符中不能包含小数点,而前面可以包含小数点。
    • 小数点:

      (1) 小数点最多出现一次(不论是否是指数的形式)。

      (2) 小数点如果出现在最后,则其前一个字符必须是数字符号。

      (3) 小数点不能出现在E或e的后面。
package com.walegarrett.offer;

/**
* @Author WaleGarrett
* @Date 2021/1/26 17:59
*/ /**
* 题目描述:
* 请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串"+100"、"5e2"、"-123"、"3.1416"、"-1E-16"、"0123"都表示数值,
* 但"12e"、"1a3.14"、"1.2.3"、"+-5"及"12e+5.4"都不是。
*/
public class Offer_20 {
public boolean isNormal(String s){
int index = 0;
if(s == null || s.equals(""))
return false;
char start = s.charAt(0);
//数字的首字母必须是+,-,0-9其他的都不符合
if(start != '+' && start != '-' && start != '.' && (start < '0' || start > '9'))
return false;
if(start == '+' || start == '-' || start == '.'){
if(start == '+' || start == '-')
index = 1;
if(s.length() == 1)
return false;
if (s.charAt(1) != '.' && (s.charAt(1) < '0' || s.charAt(1) > '9'))
return false;
else if(s.charAt(1) == '.' && s.length() == 2)
return false;
// if(s.charAt(1) == '.' || s.charAt(1) == 'e')
// return false;
}
//只能有一个小数点,一个+,-符号
if(s.indexOf(".") != s.lastIndexOf(".")
|| s.indexOf("+") != s.lastIndexOf("+")
|| s.indexOf("-") != s.lastIndexOf("-"))
return false;
//不可以同时存在+,-号
if(s.contains("+") && s.contains("-"))
return false; for(int i = index; i < s.length(); i++){
//除这些特殊字符外的字符都不合法
if (s.charAt(i) != '.' && (s.charAt(i) < '0' || s.charAt(i) > '9'))
return false;
}
//最多只有一个小数点
return s.indexOf(".") == s.lastIndexOf(".");
}
public boolean isNumber(String s) {
s = s.trim();
if(s.contains("e") || s.contains("E")){
int firstIndex, lastIndex;
if(s.contains("e")){
firstIndex = s.indexOf("e");
lastIndex = s.lastIndexOf("e");
}else{
firstIndex = s.indexOf("E");
lastIndex = s.lastIndexOf("E");
}
if(firstIndex != lastIndex)//存在多个e
return false;
else{
if(firstIndex == s.length() -1)//e在最后一个字符
return false;
String before = s.substring(0, firstIndex);//前半部分
String end = s.substring(firstIndex +1);//后半部分
if(!isNormal(before) || !isNormal(end))
return false;
//后半部分不能有小数点
if(end.contains("."))
return false;
}
}else{
if(!isNormal(s))
return false;
}
return true;
}
}

有限状态机:面试题20. 表示数值的字符串(有限状态自动机,清晰图解)

class Solution {
public boolean isNumber(String s) {
Map[] states = {
new HashMap<>() {{ put(' ', 0); put('s', 1); put('d', 2); put('.', 4); }}, // 0.
new HashMap<>() {{ put('d', 2); put('.', 4); }}, // 1.
new HashMap<>() {{ put('d', 2); put('.', 3); put('e', 5); put(' ', 8); }}, // 2.
new HashMap<>() {{ put('d', 3); put('e', 5); put(' ', 8); }}, // 3.
new HashMap<>() {{ put('d', 3); }}, // 4.
new HashMap<>() {{ put('s', 6); put('d', 7); }}, // 5.
new HashMap<>() {{ put('d', 7); }}, // 6.
new HashMap<>() {{ put('d', 7); put(' ', 8); }}, // 7.
new HashMap<>() {{ put(' ', 8); }} // 8.
};
int p = 0;
char t;
for(char c : s.toCharArray()) {
if(c >= '0' && c <= '9') t = 'd';
else if(c == '+' || c == '-') t = 's';
else if(c == 'e' || c == 'E') t = 'e';
else if(c == '.' || c == ' ') t = c;
else t = '?';
if(!states[p].containsKey(t)) return false;
p = (int)states[p].get(t);
}
return p == 2 || p == 3 || p == 7 || p == 8;
}
}

剑指 Offer 20. 表示数值的字符串 + 有限状态自动机的更多相关文章

  1. 【Java】 剑指offer(20) 表示数值的字符串

    本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集   题目 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如, ...

  2. 剑指 Offer 20. 表示数值的字符串

    方法:分为几个部分判断 DA[.B][E/eC] D 其中D表示前后的空格,需要处理,跳过即可 A可以带正负号 有符号数 B无符号数 C可以为有符号数(带+-号) 小数点.后面必须是无符号数或者没有 ...

  3. Go语言实现:【剑指offer】表示数值的字符串

    该题目来源于牛客网<剑指offer>专题. 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2",&qu ...

  4. 剑指offer——22表示数值的字符串

    题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1 ...

  5. 剑指Offer 53. 表示数值的字符串 (字符串)

    题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1 ...

  6. 《剑指offer》-表示数值的字符串

    请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1416&q ...

  7. [剑指Offer] 53.表示数值的字符串

    题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1 ...

  8. [剑指offer] 53. 表达数值的字符串

    题目描述 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3.1 ...

  9. 剑指offer:表示数值的字符串

    题目描述: 请实现一个函数用来判断字符串是否表示数值(包括整数和小数).例如,字符串"+100","5e2","-123","3. ...

随机推荐

  1. hdu 01 Matrix

    Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission ...

  2. Codeforces #637 div2 B. Nastya and Door

    题意:给你一个数组a,定义:若a[i]>a[i]&&a[i]>a[i-1],则a[i]为峰值,求长度为k的区间内峰值最多能为多少,并输出这个区间的左端点(区间需要将峰的左边 ...

  3. 实战交付一套dubbo微服务到k8s集群(7)之交付dubbo服务的消费者集群到K8S

    构建dubbo-demo-consumer,可以使用和dubbo-demo-service的流水线来构建 1.登录jenkins构建dubbo-demo-consumer 2.填写构建dubbo-de ...

  4. 爬虫入门六 总结 资料 与Scrapy实例-bibibili番剧信息

    title: 爬虫入门六 总结 资料 与Scrapy实例-bibibili番剧信息 date: 2020-03-16 20:00:00 categories: python tags: crawler ...

  5. Verilog hdl 实现单周期cpu

    参考计组实验测试指令 - 简书,添加了一些细节. 1.添加 bne指令 修改 ctrl.v       之后修改mipstestloopjal_sim.asm,mars dump 为 bnetest. ...

  6. 操作系统 part5

    1.线程安全 线程安全就是多线程访问时,采用了加锁机制,当一个线程访问该类的某个数据时,进行保护,其他线程不能进行访问直到该线程读取完,其他线程才可使用.不会出现数据不一致或者数据污染. 线程不安全就 ...

  7. window.onresize使用实例

    <!DOCTYPE html> <html> <head> <title>请调整浏览器窗口</title> <meta charset ...

  8. ES6 Map All In One

    ES6 Map All In One Map 字典/地图 Set 集合 https://developer.mozilla.org/en-US/docs/Web/JavaScript/Referenc ...

  9. PDF transform to PPT online & free

    PDF transform to PPT online & free > Speaker Deck Share Presentationswithout the Mess Speaker ...

  10. You, Me & SVG!

    You, Me & SVG! SVG refs code-school-you-me-svg https://www.youtube.com/watch?v=a8Y0L5q63y8 https ...