#367. #6082. 点亮的水晶
#6082. 点亮的水晶
说明
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
)- 空字符串
输入格式
仅有一行,包含 kkk
输出格式
仅有一行,包含你的正则表达式 RRR
样例
样例输入
2
样例输出
(0|1)*0
样例解释
二进制数是 2 的倍数,当且仅当其末位为 0
数据范围与提示
有 10 个测试点,第 iii 个测试点有 k=ik = ik=i
程序输出不得超过 50000 个字符
来源:是 https://www.codewars.com/kata/regular-expression-check-if-divisible-by-0b111-7/ 的加强版