正则表达式 – 我可以使用正则表达式来搜索数字的倍数吗?

我正在搜索一个大项目的所有例子,我已经宣布了一个数组,[48]作为大小或任何倍数的48.

我可以使用正则表达式函数来查找48 * n的匹配吗?

谢谢.

在这里你去(在 PHP的PCRE语法):
^(0*|(1(01*?0)*?1|0)+?0{4})$

用法

preg_match('/^(0*|(1(01*?0)*?1|0)+?0{4})$/',decbin($number));

现在,为什么它的作品:

我们知道,48只是3 * 16,16只是2 * 2 * 2 * 2.所以,任何可被2 ^ 4整除的数字将在其二进制表示0中具有4个最多位.因此,通过以0 {4} $结束正则表达式相当于该数可被2 ^ 4(或16)整除.那么,左边的位需要被3整除.所以使用this answer的正则表达式,我们可以判断它们是否可被3整除.所以如果整个正则表达式匹配,这个数字可以被3和16整除,因此48 …

QED …

(注意,当$number为0时,前导0 |个案处理失败的匹配).我已经测试了所有数字从0到48 ^ 5,它正确匹配每次…

相关文章

一、校验数字的表达式 1 数字:^[0-9]*$ 2 n位的数字:^d{n}$ 3 至少n位的数字:^d{n,}$ 4 m-n位的数字...
正则表达式非常有用,查找、匹配、处理字符串、替换和转换字符串,输入输出等。下面整理一些常用的正则...
0. 注: 不同语言中的正则表达式实现都会有一些不同。下文中的代码示例除特别说明的外,都是使用JS中的...
 正则表达式是从信息中搜索特定的模式的一把瑞士军刀。它们是一个巨大的工具库,其中的一些功能经常...
一、校验数字的表达式 数字:^[0-9]*$ n位的数字:^\d{n}$ 至少n位的数字:^\d{n,}$ m-n位的数...
\ 将下一字符标记为特殊字符、文本、反向引用或八进制转义符。例如,“n”匹配字符“n”。“\n...