剑指Offer:面试题20:表示数值的字符串

记录一下书上的写法。很整洁,每个函数的功能都显而易见。自己开始写的一堆if else语句像是一坨屎。另外注释的地方短路效应也要注意一下。总之这题还挺考察代码素质的(我这种就不存在什么素质。。乱糟糟一团)

#include<iostream>
using namespace std;
bool is_unsignedint(char** str);
bool is_int(char** str);
bool is_numeric(char* str) {
	if (str == NULL) {
		return false;
	}
	bool res = is_int(&str);
	if (*str == '.') {
		str++;
		res=is_unsignedint(&str) or res;		//短路效应
	}
	if (*str == 'E' or *str == 'e') {
		str++;
		res = res and is_int(&str);
	}
	return res and str and *str == '\0';
}
bool is_unsignedint(char** str) {
	char* begin = *str;
	while (*str and **str >= '0' and **str <= '9') {
		(*str)++;
	}
	return *str > begin;
}
bool is_int(char** str) {
	if (not *str) {
		return false;
	}
	if (**str == '+' or **str == '-') {
		++*str;
	}
	return is_unsignedint(str);
}
int main(){
	while (1) {
		char x[10];
		cin >> x;
		cout << is_numeric(x);
	}
}
posted @ 2019-11-26 23:15  NeoZy  阅读(119)  评论(0编辑  收藏  举报