有效的括号字符串

翻译

Valid Parenthesis String:有效的括号字符串

问题描述

给定一个只包含三种字符的字符串:( ,) 和 *,写一个函数来检验这个字符串是否为有效字符串。有效字符串具有如下规则:

  1. 任何左括号 ( 必须有相应的右括号 )。
  2. 任何右括号 ) 必须有相应的左括号 ( 。
  3. 左括号 ( 必须在对应的右括号之前 )。
  4. * 可以被视为单个右括号 ) ,或单个左括号 ( ,或一个空字符串。
  5. 一个空字符串也被视为有效字符串。
1
2
3
4
5
6
7
8
9
10
() //ok
(*)//ok
(*))//ok
(())()//ok
()()//ok
()( //error
)(( //error
())//error
()()()//ok
)( //error

算法

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public boolean f(String s) {
int b = 0;
char[] chars = s.toCharArray();
for (char c : chars) {
if (String.valueOf(c).equals("(")) {
b++;
} else if (String.valueOf(c).equals(")")) {
b--;
if (b < 0) {
return false;
}
}
}
return b == 0;
}

时间复杂度 O(n)
空间复杂度 O(1)