Powershell, 89 bytes
"$args"-notmatch'(.)(.*)(.)'-or(($m=$Matches).1-ge$m.3-and(.\g(''+(+$m.1+$m.3)%10+$m.2)))
Importante! O script se chama recursivamente. Então salve o script comog.ps1
arquivo no diretório atual. Além disso, você pode chamar uma variável de bloco de script em vez de arquivo de script (consulte o script de teste abaixo). Isso chama tem o mesmo comprimento.
Nota 1: O script usa uma avaliação lenta dos operadores lógicos -or
e -and
. Se "$args"-notmatch'(.)(.*)(.)'
for True
, a subexpressão correta de -or
não será avaliada. Além disso, se ($m=$Matches).1-ge$m.3
for False
, a subexpressão correta de -and
também não será avaliada. Portanto, evitamos recursões infinitas.
Nota 2: A expressão regular '(.)(.*)(.)'
não contém âncoras de início e fim porque a expressão(.*)
é gananciosa por padrão.
Script de teste
$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"
}
Saída:
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 bytes
Sem recursão. Nenhuma dependência de nome de arquivo e nenhuma dependência de nome de bloco de script.
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]
Um PowerShell converte implicitamente um operando direito em um tipo de operando esquerdo. Portanto, $s-ge$s%10
calcula o operando direito $s%10
como integer
e o compara como um string
tipo porque o operando esquerdo é string
. E 2+$s[0]+$s
converte um caractere $s[0]
e uma string $s
para integer
porque o operando esquerdo 2
é inteiro.
$s|% S*g 1($s.Length-2)
é um atalho para$s.Substring(1,($s.Length-2))