小练习:vaild number
1.描述
给定字符串,若该字符串表示的是数字,则输出true,否则输出false
2.分析
题目一看感觉不难,做起来却很麻烦,首先是数字的各种表示要知道,然后就是对这些不同形式的数字进行筛选判断。该题目中合法数字的表示形式如下:
± // 前缀有正负号合法
1.2
.
.
1e2
.e2
1e± //以上数字中间不含空格
思路:
总原则,出现非法字符(.e±1234567890及空格之外的)直接false,'.''e'出现两次以上的直接false,有效字段中包含空格的直接false,以'e'开头和以'e''+''-'结尾的直接false
01.首先是缩减字符到有效字段,即一头一尾各一个哨兵,然后相向排除(空格),全都到达合法字符处后结束缩减,例如:
" 12 ee 23 " -> "12 ee 23" // 对于有效字段内部不检查
" e12 " -> false
" 123+ " ->false
02.由上步骤确定的两个首位哨兵位置,对有效字段内部进行排查
03.在有效字段内逐个检查,出现非法字符或者出现空格的直接false,否则对出现的有效字符进行分类检查
3.代码
bool isNumber(string s){
const char* sp = s.c_str();
int eFlag = , dotFlag = , startFlag = , spaceFlag = , numFlag = , dotEFlag = , signFlag = , esignFlag = , signnumFlag = ; //一些标志位
int i = , j = s.length() - ; // 设立哨兵
for (;;) // 压缩头尾,提取有效字段
{
if (sp[i]< || sp[i]>)
{
if (sp[i] != '+'&&sp[i] != '-'&&sp[i] != '.'&& sp[i] != ' ' && sp[i] != 'e' || i>j) //非法字符检查
return false;
}
//-----------------------------------------------------+
if (sp[i] == 'e') // 头--->
return false;
else
{
if (sp[i] == ' ' || sp[i] == '+' || sp[i] == '-')
{
if (signFlag)
return false;
if (sp[i] == '+' || sp[i] == '-')
signFlag = ;
i++;
}
else
startFlag = ;
}
//-----------------------------------------------------+
if (sp[j] == 'e' || sp[j] == '+' || sp[j] == '-') // <---尾
return false;
else
{
if (sp[j] == ' ')
j--;
else if (startFlag)
break;
}
}
//-----------------------------------------------------+
for (; i<j + ; i++) //对有效字段内进行检查
{
if (sp[i]< || sp[i]>)
{
if (sp[i] != '.'&& sp[i] && sp[i] != 'e'&&sp[i] != '+'&&sp[i] != '-') // 排除非法字符
return false;
}
else
{
numFlag = ;
}
//-----------------------------------------------------+
if (sp[i] == 'e') // 为'e'的情况
{
eFlag++;
esignFlag = i; //用来检查 "1e±1"类型
if (i == && dotEFlag) //用来排除".e1"类型
return false;
if (i == (j - ))
dotEFlag = ;
if (eFlag>)
return false;
}
//-----------------------------------------------------+
else if (sp[i] == '.') // 为 '.' 的情况 非法情况是 ".e1""..1"等
{
dotFlag++;
if (i == )
dotEFlag = ;
if (dotEFlag&&i == j) // 用来检查e在.前
return false;
if (eFlag)
return false;
if (dotFlag>)
return false;
}
//-----------------------------------------------------+
else if (sp[i] == '+' || sp[i] == '-') //为'+''-'的情况
{
signnumFlag++;
if (i>esignFlag + ||!eFlag)
return false;
if (signnumFlag>)
return false;
}
}
if (!numFlag)
return false;
return true;
}
经过测试,算法可以使用。
小练习:vaild number的更多相关文章
- 374. Guess Number Higher or Lower
We are playing the Guess Game. The game is as follows: 我们来玩一个游戏,规则如下: I pick a number from 1 to n. Y ...
- 230. 二叉搜索树中第K小的元素
230. 二叉搜索树中第K小的元素 题意 给定一个二叉搜索树,编写一个函数 kthSmallest 来查找其中第 k 个最小的元素. 你可以假设 k 总是有效的,1 ≤ k ≤ 二叉搜索树元素个数. ...
- Oracle类型number与PG类型numeric对比和转换策略
Oracle 11g number 任意精度数字类型 http://docs.oracle.com/cd/B28359_01/server.111/b28318/datatype.htm#CNCPT3 ...
- 数位DP || Gym 101653R Ramp Number
每一位都大于等于前一位的数叫Ramp Number 给一个数,如果不是Ramp Number输出-1,如果是Ramp Number输出比它小的Ramp Number的个数 只和每一位上的数字有关 #i ...
- java类的封装 继承 多态
1.猜数字小游戏 package cn.jiemoxiaodi_02; import java.util.Scanner; /** * 猜数字小游戏 * * @author huli * */ pub ...
- Flex Array内置排序方法的使用
在Array类中,提供内置的排序方法.排序是在软件开发的过程中,经常遇到的问题.通过这些内置的方法,可以快速轻便的进行排序操作. Array类提供sort方法对Array实例进行排序.sort方法没有 ...
- jsf服务器端验证用户输入
服务器端验证用户输入数据步骤 1 html页面上插入要输入数据控件 <h:inputText size="10" value="#{commodityBean.fo ...
- <C++Primer>第四版 阅读笔记 第二部分 “容器和算法”
泛型算法中,所谓"泛型(generic)"指的是两个方面:这些算法可作用于各种不同的容器类型,而这些容器又可以容纳多种不同类型的元素. 第九章 顺序容器 顺序容器的元素排列次序与元 ...
- python 输出颜色的与样式的方法
上次遇到这个问题就想写下来,其实当时我也不怎么会,老师说这个东西不需要理解,只需要死记硬背,写的多了就记住了,所以今天搜集了几篇文章,加上自己的理解,写下了这篇python 输出颜色的样式与方法的文章 ...
随机推荐
- XDU 1022 (数论筛法+前缀和)
解法一:数论筛法+前缀和 //其实题目中f[n]的值可理解为存在多少个整数对使a*b<=n #include<cstdio> #define N 1007 #define maxn ...
- java内存回收
java中引用类型 强引用 Persnon p = new Person(); 当指向Person对象的引用计数为0时,Person对象才能被垃圾回收器回收. 软引用 SoftReference&l ...
- netbeans许可证模板设置
工具->模板->设置 user=your name 工具->模板->许可证->默认许可证 <#if licenseFirst??>${licenseFirst ...
- java 2017/6/26杂记
mkdirs()可以建立多级文件夹, mkdir()只会建立一级的文件夹, 如下: new File("/tmp/one/two/three").mkdirs(); 执行后, 会建 ...
- get请求参数为中文,参数到后台出现乱码(注:乱码情况千奇百怪,这里贴我遇到的情况)
前言 get请求的接口从页面到controller类出现了乱码. 解决 参数乱码: String param = "..."; 使用new String(param.getByte ...
- Python学习笔记之Centos6.9安装Python3.6
0x00 注意 如果本机安装了python2,尽量不要管他,使用python3运行python脚本就好,因为可能有程序依赖目前的python2环境, 比如yum!!!!! 不要动现有的python2环 ...
- linux挂载iso,u盘,分区,squashfs压缩文件
常见分区加载方法: mount挂载iso文件: #mkdir /mnt/iso1 #mount –o loop linuxsetup.iso /mnt/iso1 在linux 不需要虚拟光驱,就可以直 ...
- Java学习第四周学习笔记
20145307<Java程序设计>第4周学习总结 教材学习内容总结 继承与多态 继承 继承作为面向对象的第二大特征,基本上就是避免多个类间重复定义共同行为.即当多个类中存在相同属性和行为 ...
- 20145240《网络对抗》PC平台逆向破解_advanced
PC平台逆向破解_advanced shellcode注入 Shellcode实际是一段代码(也可以是填充数据),是用来发送到服务器利用特定漏洞的代码,一般可以获取权限.另外,Shellcode一般是 ...
- 回到HTML〇
HTML(HyperText Markup Language),用来向浏览器标示文档的所有“内容”与“结构”. 抱着温故而知新的态度,在这里通过“回到HTML”系列文章,重新梳理一下HTML的相关知识 ...