Hay un error en el codigo, despues lo corrijo.
Bueno, el error para quien quiera saberlo es que comprobaba mal la multiplicidad de 5...
Me he quedado hoy pensando... y hay una forma realmente sencilla de obtener el ultimo digito de una cifra... sin usar cadenas de textoooo
data:image/s3,"s3://crabby-images/b8f67/b8f676b6c2e17a8b6aa1b1e8013e113452c1f15a" alt=":o"
Simplemente hay que obtener el resto al dividir por 10 (aka Mod 10)
data:image/s3,"s3://crabby-images/e3ae6/e3ae63d49633e069ee10f4b7f4d5a92c228ca9b1" alt=":laugh:"
He hecho este codigo
data:image/s3,"s3://crabby-images/af625/af6256ab35d8def1e2b55e4f7a3de8b2bc71b462" alt=":D"
, si no me equivoco es la mas rapida (sin contar la de Cobein, que no acaba de funcionar)
Public Function IsItPrime(ByVal lNumber As Long) As Boolean
Dim i As Long
If lNumber < 10 Then
If lNumber = 2 Then IsItPrime = True: Exit Function
If lNumber = 5 Then IsItPrime = True: Exit Function
If lNumber = 1 Then Exit Function
ElseIf (lNumber And 1) Then
Select Case (lNumber Mod 10)
Case 1, 3, 7, 9
For i = 3 To Sqr(lNumber) Step 2
If (lNumber Mod i) = 0 Then Exit Function
Next i
IsItPrime = True
End Select
End If
End Function