- 正则表达式解决。
- 注意regex 和 regex_match
- 注意常用的正则的语法。\表示转义,\d这个整数需要转义才可以使用。
- ()用来匹配一块字段,可以后加?号代表该字段可有可无
- []里面的字符有且只能出现一次,可以加*+来控制次数。
- ”“来包含这个串
#include<bits/stdc++.h>
class Solution {
public:
/**
* 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
*
*
* @param str string字符串
* @return bool布尔型
*/
bool isNumeric(string str) {
// write code here
if(!str.length()) return false;
string s = trim(str);//删除所有空格
if(s.length()==0){//输入的是一个空格
return false;
}
return regex_match(s, regex("[+-]?(\\d+|\\d+\\.\\d*|\\.\\d+)([eE][+-]?\\d+)?"));
}
//自定义c++ trim函数
string trim(string str){
auto pos = str.begin();//从头开始找
while(1){
pos = find(pos,str.end(),' ');
if(pos==str.end()){
break;
}
str.erase(pos);
}
return str;
}
};