剑指offer之字符串是否为数值
1. 题目
这是《剑指offer》上的一道题,刚开始觉得这是一道挺简单的题目,后来发现自己太年轻了,考虑的因素太少了,思考了而是分钟还是无从下手,看了作者的思路深深被他折服了,题目如下:
请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串 "+100"、"5e2"、"-123"、"3.1415" 以及 "-1E-16" 都表示数值,但"12e"、"1a3.14"、"1.2.3"、"+-5" 以及 "12e+5.4" 都不是
2. 思路
表示数值的字符串遵循模式 A[.[B]][e|EC] 或者 .B[e|EC],其中 A 为数值的整数部分,B 紧跟着小数点为数值的小数部分,C 紧跟着 'e' 或者 'E' 为数值的指数部分。在消暑利可能没有数值的整数部分。例如,小数 .123 等于 0.123。因此 A 部分不是必需的。如果一个数没有整数部分,那么它的小数部分不能为空。
上述 A 和 C 都是可能以 '+' 或者 '-' 开头的 0~9 的数位串;B 也是 0~9 的数位串,但前面不能有正负号。
以表示数值的字符串 "123.45e+6" 为例,"123" 是它的整数部分 A,"45" 是它的小数部分 B,"+6" 是它的指数部分 C。
判断一个字符串是否符合上述模式,首先应该扫描 0~9 的数位,也就是上面数值中表示整数的 A 部分。如果遇到小数点,则开始扫描数值小数部分 B。如果遇到 'e' 或者 'E',则开始扫描表示数值指数的 C 部分。根据这样的思路,给出参考代码:
public class Main{
public boolean isNumeric(char[] str){
if(str==null)
return false;
// 这个数组就一个元素,存储遍历字符串的下标
int[] index = {0};
// 先遍历字符串的整数部分
boolean numeric = scanInteger(str,index);
// 碰到小数点时,开始遍历 B 部分
if(index[0]<str.length && str[index[0]]=='.'){
index[0]++;
/*
* 这里使用 || 的原因
* 1. 小数可以没有整数,如 .123 等于 0.123
* 2. 小数点后面可以没有数字,如 223. 等于 233.0
* 3. 当然,小数点前面和后面都可以有数字,如 2233.444
*/
numeric = scanUnsignedInteger(str,index) || numeric;
}
// 如果出现 'e' 或者 'E',开始遍历指数部分
if(index[0]<str.length && (str[index[0]]=='e' || str[index[0]]=='E')){
index[0]++;
/*
* 这里使用 && 的原因
* 1. 当 e 或 E 前面没有数字时,整个字符串不能表示数字,如 .e1、e2。
* 2. 当 e 或 E 后面没有整数时,整个字符串不能表示数字,如 23e、23e+5.4
*/
numeric = numeric && scanInteger(str,index);
}
return index[0]==str.length && numeric;
}
/*
* 该函数用来扫描字符串中 0~9 的数位(类似于一个无符号整数),可以用来匹配前面数值
* 模式中的 B 部分
*/
private boolean scanInteger(char[] str,int[] index){
if(index[0]<str.length && (str[index[0]]=='+' || str[index[0]]=='-'))
index[0]++;
return scanUnsignedInteger(str,index);
}
/*
* 该函数扫描可能以表示正负号的 '+' 或者 '-' 开头的 0~9 的数位(类似于一个有符号整数)
* 可以用来匹配前面数值模式中的 A 和 C 部分。
*/
private boolean scanUnsignedInteger(char[] str,int[] index){
int before = index[0];
while(index[0]<str.length && str[index[0]]>='0' && str[index[0]]<='9')
index[0]++;
return index[0]>before;
}
}
更多《剑指offer》的题目以及源代码可以参考我的 github 。
剑指offer之字符串是否为数值的更多相关文章
- 剑指Offer:字符串排列【38】
剑指Offer:字符串排列[38] 题目描述 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bc ...
- 剑指 Offer 38. 字符串的排列 + 无重复元素的全排列
剑指 Offer 38. 字符串的排列 Offer_38 题目描述 解题思路 可以使用递归实现全排列,每次都确定一个数的位置,当所有位置的数都确定后即表示一个排列. 但是考虑到本题需要排除重复的排列, ...
- 剑指 Offer 38. 字符串的排列
剑指 Offer 38. 字符串的排列 输入一个字符串,打印出该字符串中字符的所有排列. 你可以以任意顺序返回这个字符串数组,但里面不能有重复元素. 示例: 输入:s = "abc" ...
- 【剑指Offer】字符串的排列 解题报告(Python)
[剑指Offer]字符串的排列 解题报告(Python) 标签(空格分隔): LeetCode 题目地址:https://www.nowcoder.com/ta/coding-interviews 题 ...
- 剑指offer 67. 字符串转换为整数(Leetcode 8. String to Integer (atoi))
题目:剑指offer 67题 需要考虑的情况:空指针.nullptr.空字符串"".正负号.数值溢出.在写代码的时候对这些特殊的输入都定义好合理的输出.可以定义一个全局布尔型变量g ...
- 【Java】 剑指offer(38) 字符串的排列
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 输入一个字符串,打印出该字符串中字符的所有排列.例如输入字符串ab ...
- 【Java】 剑指offer(50-1) 字符串中第一个只出现一次的字符
本文参考自<剑指offer>一书,代码采用Java语言. 更多:<剑指Offer>Java实现合集 题目 在字符串中找出第一个只出现一次的字符.如输入"abacc ...
- 【剑指offer】字符串的组合
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/mmc_maodun/article/details/26405471 转载请注明出处:http:// ...
- Go语言实现:【剑指offer】字符串的排列
该题目来源于牛客网<剑指offer>专题. 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,b ...
随机推荐
- CocosCreator之AssetBundle使用方案分享
前言 Creator2.4 推出了AssetBundle,使得所有平台都有了分包的能力.那么该如何使用这个强大的功能呢?下面介绍一下我个人的用法,仅供参考,水平有限,非喜勿喷. 根据官方文档 指出,之 ...
- CSS-好玩的样式(用高斯模糊制作平缓突起)
一.效果图: 应用: 二.上代码 <!DOCTYPE html> <html lang="en"> <head> <meta charse ...
- drf☞jwt自动签发与手动签发
目录 一.自动签发 二.手动签发 一.自动签发 urls from rest_framework_jwt.views import obtain_jwt_token # 使用jwt自带的登录视图 ur ...
- 耐心看,1个Dubbo漏洞,35道必问面试题,Dubbo没什么可神秘的
Dubbo漏洞 无意中在网上看到了这样的一条新闻,说是我们360监测发现了Dubbo官方发布的危险漏洞通告,而且尴尬的是,世界上受影响最大的居然是中国,有图有真相 我感觉这也从侧面证明了一件事情,就是 ...
- Python 3.x 安装PyQt5
一. 安装PyQt5 官方要求Python版本:Python >=3.5 打开命令行 输入 pip install PyQt5 PyQt5安装成功 安装完成功PyQt5后发现没有design ...
- python爬虫入门(2)----- lxml
lxml 简介 lxml使用xpath对xml进行解析,XPath 是一门在 XML 文档中查找信息的语言.XPath 可用来在 XML 文档中对元素和属性进行遍历. 参考官方文档:https://l ...
- .net core 拦截socket
using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Net ...
- 新阿里云服务器从0开始配置为python开发环境
由于每次打开linux虚拟机比较麻烦,于是尝试一下云服务器,在阿里云领取了一个月的试用服务器,这里记录一下新服务器从0配置成python开发环境的步骤,以便以后配置新服务器时有个参考. 免费领取一个月 ...
- DJANGO-天天生鲜项目从0到1-001-环境框架搭建
本项目基于B站UP主‘神奇的老黄’的教学视频‘天天生鲜Django项目’,视频讲的非常好,推荐新手观看学习 https://www.bilibili.com/video/BV1vt41147K8?p= ...
- Error: no such table: device;的问题的解决,去掉表名device后面的分号;
sqlite> .mode csvsqlite> .import device.txt device;Error: no such table: device;sqlite> .im ...