Powershell,89个字节
"$args"-notmatch'(.)(.*)(.)'-or(($m=$Matches).1-ge$m.3-and(.\g(''+(+$m.1+$m.3)%10+$m.2)))
重要!该脚本以递归方式调用自身。因此,将脚本另存为g.ps1
当前目录中的文件。您也可以调用脚本块变量而不是脚本文件(请参见下面的测试脚本)。该呼叫具有相同的长度。
注意1:脚本使用逻辑运算符-or
和的惰性评估-and
。如果"$args"-notmatch'(.)(.*)(.)'
为True
,-or
则不评估的正确子表达式。另外,如果($m=$Matches).1-ge$m.3
是,False
则-and
也不会评估的正确子表达式。因此,我们避免了无限递归。
注意2:正则表达式'(.)(.*)(.)'
不包含开始和结束锚点,因为该表达式(.*)
默认情况下是贪婪的。
测试脚本
$g={
"$args"-notmatch'(.)(.*)(.)'-or(($m=$Matches).1-ge$m.3-and(&$g(''+(+$m.1+$m.3)%10+$m.2)))
}
@(
,(2632, $true)
,(92258, $true)
,(60282, $true)
,(38410, $true)
,(3210, $true)
,(2302, $true)
,(2742, $true)
,(8628, $true)
,(6793, $true)
,(1, $true)
,(2, $true)
,(10, $true)
,(100, $true)
,(55, $true)
,(121, $true)
,(6724, $false)
,(47, $false)
,(472, $false)
,(60247, $false)
,(33265, $false)
,(79350, $false)
,(83147, $false)
,(93101, $false)
,(57088, $false)
,(69513, $false)
,(62738, $false)
,(54754, $false)
,(23931, $false)
,(7164, $false)
,(5289, $false)
,(3435, $false)
,(3949, $false)
,(8630, $false)
,(5018, $false)
,(6715, $false)
,(340, $false)
,(2194, $false)
) | %{
$n,$expected = $_
#$result = .\g $n # uncomment this line to call a script file g.ps1
$result = &$g $n # uncomment this line to call a script block variable $g
# the script block call and the script file call has same length
"$($result-eq-$expected): $result <- $n"
}
输出:
True: True <- 2632
True: True <- 92258
True: True <- 60282
True: True <- 38410
True: True <- 3210
True: True <- 2302
True: True <- 2742
True: True <- 8628
True: True <- 6793
True: True <- 1
True: True <- 2
True: True <- 10
True: True <- 100
True: True <- 55
True: True <- 121
True: False <- 6724
True: False <- 47
True: False <- 472
True: False <- 60247
True: False <- 33265
True: False <- 79350
True: False <- 83147
True: False <- 93101
True: False <- 57088
True: False <- 69513
True: False <- 62738
True: False <- 54754
True: False <- 23931
True: False <- 7164
True: False <- 5289
True: False <- 3435
True: False <- 3949
True: False <- 8630
True: False <- 5018
True: False <- 6715
True: False <- 340
True: False <- 2194
Powershell,90个字节
没有递归。没有文件名依赖性,也没有脚本块名称依赖性。
for($s="$args";$s[1]-and$s-ge$s%10){$s=''+(2+$s[0]+$s)%10+($s|% S*g 1($s.Length-2))}!$s[1]
Powershell将右操作数隐式转换为左操作数的类型。因此,$s-ge$s%10
将右操作数计算$s%10
为integer
,并将其比较为string
因为左操作数的类型为string
。并且2+$s[0]+$s
将char $s[0]
和string 转换为$s
,integer
因为左操作数2
为整数。
$s|% S*g 1($s.Length-2)
是通往的捷径$s.Substring(1,($s.Length-2))