《剑指offer》面试题 20:表示数值的字符串(C++实现)

题目

请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。例如,字符串“+100”、“5e2”、“-123”、“3.1416”及“-1E-16”都表示数值,但“12e”、“1a3.14”、“1.2.3”、“+-5”及“12e+5.4”都不是。

代码

/**
 * 注意||和&&前后调用函数的放置 需要符合 短路规则 以及减少计算量
 */
#pragma once

// 题目:请实现一个函数用来判断字符串是否表示数值(包括整数和小数)。

/**
 * A.B e|E C
 * A C是可带正负号的整数 B为整数
 * 子函数参数用二次指针
 */

bool isNumeric(const char* str)
{
	if (str == nullptr)
		return false;

	bool numeric = scanInteger(&str);	// 先扫A	str有后移
	if (*str == '.')
	{
		++str;
		numeric = scanUnsignedInteger(&str) || numeric;// 由于短路规则 必须先扫B 否则str没有后移
	}
	if (*str == 'e' || *str == 'E')
	{
		++str;
		numeric = numeric && scanInteger(&str);// numeric放前面可减少可能的计算
	}

	return numeric && *str == '\0';
}

// 扫描A C
bool scanInteger(const char** str)
{
	if (**str == '+' || **str == '-')
		++(*str);

	return scanUnsignedInteger(str);
}

// 扫描B
bool scanUnsignedInteger(const char** str)
{
	const char* before = *str;
	while(**str != '\0' && **str >= '0' && **str <= '9')
		++(*str);

	return *str > before;	// 若不相等说明有扫到数值
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值