470 用rand7()实现rand10()
我们可以用拒绝采样的方法实现 \textit{Rand10()}Rand10()。在拒绝采样中,如果生成的随机数满足要求,那么就返回该随机数,否则会不断生成,直到生成一个满足要求的随机数为止。
我们只需要能够满足等概率的生成 1010 个不同的数即可,具体的生成方法可以有很多种,比如我们可以利用两个 \textit{Rand7()}Rand7() 相乘,我们只取其中等概率的 1010 个不同的数的组合即可,当然还有许多其他不同的解法,可以利用各种运算和函数的组合等方式来实现。
class Solution extends SolBase {
public int rand10() {
int row, col, idx;
do {
row = rand7();
col = rand7();
idx = col + (row - 1) * 7; //减1 是为了只生成1~40的数
} while (idx > 40);
return 1 + (idx - 1) % 10;
}
}
正则表达式
基本元素
1. 普通字符: 除 *, ? , \, (, ), [, ], -, . , +, ^, $, {, } , 以外的字符匹配它自身, 比如 a 匹配 a
2. 点号 . : 匹配任意不包括换行符的单个字符。比如, sa. 可匹配 sat, sa*, sa[ 等。
3. 字符组[characters] :匹配字符组中指定字符集合中的任意单个字符: 比如 [abc] 将匹配 a 或 b 或 c , ca[ptb] 将匹配 cap, cat 或 cab。
4. 排除性字符组[^characters] : 匹配字符组中指定字符集合之外的任意单个字符:
比如, [^abc] 将匹配除了 a,b,c 之外的任意单个字符。
ca[^ptb],将匹配 caX 的文本,除了 cap, cat, cab, 注意,这里是匹配一个非指定的字符,而不是不匹配。
5. 范围字符组: [char1-char2] 将匹配从char1 到 char2 之间的任意单个字符(按照ASCII编码)。
比如, [a-z] 匹配任意小写字符; [A-Z] 匹配任意大写字符 ; [0-9] 匹配任意数字; [a-zA-Z0-9] 匹配任意大小写字符或数字。
6. 特殊字符: 凡是在正则式中具有特殊含义的字符,要匹配字符本身(将其作为普通文本)都必须使用反斜线 \ 进行转义;通常需要转义的字符有: . + * ? { } [ ] ( ) - \ ^ $。
比如, 匹配 . 的正则式是 \. , 匹配 \ 的正则式是 \\ , 匹配 ( 的正则式是 \( ;要匹配 (ab) 的正则表达式是 \(ab\) ; 要匹配 a? 的表达式是 a\? ; a? 将匹配空或单个a。
7. 匹配空白字符:
\f 换页 \n 换行 \r 回车 \t 制表符 \v 垂直制表符 \s 匹配任意空白符,包括上述任意一种
8. 字符类: <==> 等价于
\d <==> [0-9] 任意单个数字 \D <==> [^0-9] 任意单个的非数字字符
\w <==> [a-zA-Z0-9_] \W <==> [^a-zA-Z0-9_]
\s <==> [\f\n\r\t\v ] \S <==> [^\f\n\r\t\v ]
9. POSIX 字符类: 例如: [:digit:] <==> [0-9] ; [:alpha:] <==> [a-zA-Z] ; [:alnum:] <==> [a-zA-Z0-9]
具体应用时要再加一层括号,比如 TEST[[:digit:]] 匹配 TEST0 - TEST9。