leetcode - valid number 正则表达式解法

import java.util.regex.Pattern;
public class Solution {
    Pattern p = Pattern.compile("^[\\+\\-]?((\\d+(\\.\\d*)?)|(\\.\\d+))(e[\\+\\-]?\\d+)?$");
    public boolean isNumber(String s) {
        String ss = s.trim();
        return p.matcher(ss).matches();
    }
}

偷懒,用了正则表达式。不过也试了9次才过。难怪通过率那么低。

Pattern p 的编译一定要放在函数外面,否则会TLE。

posted @ 2013-10-11 23:30  Midnightcat  阅读(639)  评论(0编辑  收藏  举报