Flandre 的背后的水晶,会按照她的心情点亮。我们可以把水晶点亮与否读成一个二进制数,像是 101001001000111100010000001
这样的。
- Sakuya:这个数是 7 的倍数啊
- F:你是怎么知道的
- S:我用正则表达式啊
- F:那你现在多了一个问题了
你现在多了一个问题了!给定一个数 kkk,请回答一个正则表达式 RRR,使得对于任意 SSS,RRR 匹配字符串 SSS 当且仅当 SSS 是一个 kkk 的倍数的二进制数。
关于正则表达式:你的正则表达式只能使用以下字符:
01()|+*?
我们使用全串匹配测试,所以你不需要使用 ^
和 $
。
关于 SSS:我们对你的正则表达式测试的 SSS 符合以下条件:
- SSS 仅由
0
和1
组成,且非空 - SSS 不会有前导
0
,也不会就是0
举例来说,当 k=7k = 7k=7 时,我们要求你给出的 RRR 匹配以下字符串:
111
(十进制下为 777)101001001000111100010000001
(86276225=12325175×786276225 = 12325175 \times 786276225=12325175×7)
我们要求你给出的 RRR 不匹配以下字符串:
110
(十进制下为 666)1000111011000111101010110000
(149715632=21387947×7+3149715632 = 21387947 \times 7 + 3149715632=21387947×7+3)
我们对你给出的 RRR 是否匹配以下字符串不关心:
test
000001111
(前导 0)0
(是的,SSS 不会是0
)- 空字符串