剑指 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. Codeforces 1355 C. Count Triangles

    传送门:C - Count Triangles  题意:给你四个数A,B,C,D,求有多少个三边为x,y,z (A ≤ x ≤ B ≤ y ≤ C ≤ z ≤ D)的三角形. 题解:枚举 x=A~B, ...

  2. Codeforces 1345 D - Monopole Magnets

    传送门:D. Monopole Magnets 这一场也是很神奇了,先是推迟三天,后是评测鸡崩了,unrated... 题意:每一行,每一列必须都要至少有一个s,n要可以到所有的黑格,n的上下左右如果 ...

  3. Alternating Strings Gym - 100712D 简单dp && Alternating Strings II Gym - 100712L 数据结构优化dp

    比赛链接:https://vjudge.net/contest/405905#problem/D 题意: 给你一个长度为n的由0或1构成的串s,你需要切割这个串,要求切割之后的每一个子串长度要小于等于 ...

  4. Entity Framework中Remove、Modified实体时,在修改或删除时引发主键冲突的问题

    问题: try { string fileId = context.NewsT.Where(t => t.Id == Model.Id).FirstOrDefault().FileId; str ...

  5. [整理] LRU 算法的实现方式

    目录 概念 方法选择 实现方案(基于LinkedHashMap) 改进方案 1.LRU-K 2.Two queue 3.Multi Queue(MQ) LRU类算法对比 LRU 在 Redis 中的应 ...

  6. windows下的PyCharm设置注释字体的斜体

    操作截图如下:File --> Settings --> Editor --> Color Scheme --> Language Defaults --> Commen ...

  7. Kubernets二进制安装(8)之部署四层反向代理

    四层反向代理集群规划 主机名 角色 IP地址 mfyxw10.mfyxw.com 4层负载均衡(主) 192.168.80.10 mfyxw20.mfyxw.com 4层负载均衡(从) 192.168 ...

  8. 局部变量 static new 结构体指针

    struct ListNode { int val; ListNode* next; ListNode(int x) : val(x), next(NULL) {} }; 有一个函数利用LisNode ...

  9. 深入剖析JavaScript中的对象与原始值之间的转换机制

    我们都知道原始值之间是可以互相转换的,但是如果对象转原始值呢? 所有的对象在布尔上下文(context)中均为 true .所以对于对象,不存在 to-boolean 转换, 只有字符串和数值转换. ...

  10. u-boot 移植 --->3、S5PV210启动序列

    通过三星官方的资料S5PV210_iROM_ApplicationNote_Preliminary_20091126.pdf,了解到S5PVS10这款芯片的复位过程启动序列.芯片在出厂时就在内部固化了 ...