Powershell, 89 bytes
"$args"-notmatch'(.)(.*)(.)'-or(($m=$Matches).1-ge$m.3-and(.\g(''+(+$m.1+$m.3)%10+$m.2)))
¡Importante! El guión se llama a sí mismo de forma recursiva. Así que guarde el script como g.ps1archivo en el directorio actual. También puede llamar a una variable de bloque de script en lugar de un archivo de script (consulte el script de prueba a continuación). Eso llama tiene la misma longitud.
Nota 1: El script usa una evaluación perezosa de operadores lógicos -ory -and. Si "$args"-notmatch'(.)(.*)(.)'es, Trueentonces -orno se evalúa la subexpresión correcta de . Además, si ($m=$Matches).1-ge$m.3es Falseasí, la subexpresión correcta de -andno se evalúa también. Entonces evitamos la recursión infinita.
Nota 2: La expresión regular '(.)(.*)(.)'no contiene anclajes de inicio y fin porque la expresión (.*)es codiciosa por defecto.
Script de prueba
$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"
}
Salida:
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
Sin recursión Sin dependencia de nombre de archivo y sin dependencia de nombre de bloque 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]
Un Powershell convierte implícitamente un operando derecho en un tipo de operando izquierdo. Por lo tanto, $s-ge$s%10calcula el operando derecho $s%10como integery compárelo como stringporque el tipo del operando izquierdo es string. Y 2+$s[0]+$sconvierte un carácter $s[0]y una cadena $sen integerporque el operando izquierdo 2es entero.
$s|% S*g 1($s.Length-2)es un atajo para$s.Substring(1,($s.Length-2))