Escriba un programa (el cuerpo de la función es suficiente) que acepte una cadena de caracteres alfanuméricos y la valide de acuerdo con ISO 13616: 2007. El algoritmo para la validación es (fuente: artículo de Wikipedia en IBAN http://en.wikipedia.org/wiki/International_Bank_Account_Number ):
Validar el IBAN Un IBAN se valida convirtiéndolo en un número entero y realizando una operación básica mod-97 (como se describe en ISO 7064) en él. Si el IBAN es válido, el resto es igual a 1. El algoritmo de validación de IBAN es el siguiente:
- Verifique que la longitud total de IBAN sea correcta según el país. Si no, el IBAN no es válido. Las longitudes correctas de IBAN se pueden encontrar aquí: http://pastebin.com/kp4eECVk (también se puede encontrar a continuación), ordenadas por la longitud del número IBAN. Los primeros 2 caracteres de cada número es el código del país. Todos los demás caracteres (letras minúsculas en el pastebin, pero pueden ser cualquier caso en el IBAN real) detrás de los primeros 2 pueden ser cualquier carácter alfanumérico.
- Mueva los cuatro caracteres iniciales al final de la cadena.
- Reemplace cada letra en la cadena con dos dígitos, expandiendo así la cadena, donde A = 10, B = 11, ..., Z = 35.
- Interprete la cadena como un entero decimal y calcule el resto de ese número en la división por 97
Si el resto es 1, se pasa la prueba del dígito de verificación y el IBAN podría ser válido.
Ejemplo (banco ficticio del Reino Unido, código de clasificación 12-34-56, número de cuenta 98765432):
- IBAN: GB82 WEST 1234 5698 7654 32 - Rearrange: W E S T12345698765432 G B82 - Convert to integer: 3214282912345698765432161182 - Compute remainder: 3214282912345698765432161182 mod 97 = 1
El algoritmo moest devuelve verdadero (o un valor verdadero) si el número es válido, y falso (o un valor falso) si el número no es válido según el algoritmo. No necesita verificar si el número realmente existe, solo si es válido. El algoritmo tiene que funcionar para cada uno de los diferentes números de IBAN aprobados mencionados en el artículo de Wikipedia anterior. El algoritmo debe ser compatible con números con o sin caracteres separadores entre 2 caracteres alfanuméricos. El carácter separador puede ser puntos, espacios o guiones y un número puede contener diferentes tipos de separadores.
Se aplican las lagunas habituales: sin recursos externos, sin funciones o métodos integrados.
El tipo de rompecabezas es el código de golf. El código más corto en bytecount gana. La plantilla estándar necesaria para ejecutar el programa (por ejemplo, espacio de nombres, clase, declaración de función en OOP) no se incluye en el bytecount
Bonificación: si puede devolver el número IBAN formateado correctamente (de acuerdo con el formato nacional en wikipedia) en lugar de verdadero en el caso de un número válido, obtendrá una reducción del 25% en su puntaje. Si el número no es válido, devuelve una cadena literal con el valor "Inválido".
Copia de las longitudes de IBAN en caso de que alguna vez se elimine el pastebin:
Country;Chars;IBAN Fields
Norway;15;NOkk bbbb cccc ccx
Belgium;16;BEkk bbbc cccc ccxx
Burundi;16;BIkk nnnn nnnn nnnn
Denmark;18;DKkk bbbb cccc cccc cc
Faroe Islands;18;FOkk bbbb cccc cccc cx
Finland;18;FIkk bbbb bbcc cccc cx
Greenland;18;GLkk bbbb cccc cccc cc
Netherlands;18;NLkk bbbb cccc cccc cc
Macedonia;19;MKkk bbbc cccc cccc cxx
Slovenia;19;SIkk bbss sccc cccc cxx
Austria;20;ATkk bbbb bccc cccc cccc
Bosnia and Herzegovina;20;BAkk bbbs sscc cccc ccxx
Estonia;20;EEkk bbss cccc cccc cccx
Kazakhstan;20;KZkk bbbc cccc cccc cccc
Lithuania;20;LTkk bbbb bccc cccc cccc
Luxembourg;20;LUkk bbbc cccc cccc cccc
Costa Rica;21;CRkk bbbc cccc cccc cccc c
Croatia;21;HRkk bbbb bbbc cccc cccc c
Latvia;21;LVkk bbbb cccc cccc cccc c
Liechtenstein;21;LIkk bbbb bccc cccc cccc c
Switzerland;21;CHkk bbbb bccc cccc cccc c
Bahrain;22;BHkk bbbb cccc cccc cccc cc
Bulgaria;22;BGkk bbbb ssss ddcc cccc cc
Georgia;22;GEkk bbcc cccc cccc cccc cc
Germany;22;DEkk bbbb bbbb cccc cccc cc
Ireland;22;IEkk aaaa bbbb bbcc cccc cc
Montenegro;22;MEkk bbbc cccc cccc cccc xx
Serbia;22;RSkk bbbc cccc cccc cccc xx
United Kingdom;22;GBkk bbbb ssss sscc cccc cc
Gibraltar;23;GIkk bbbb cccc cccc cccc ccc
Israel;23;ILkk bbbn nncc cccc cccc ccc
United Arab Emirates;23;AEkk bbbc cccc cccc cccc ccc
Andorra;24;ADkk bbbb ssss cccc cccc cccc
Czech Republic;24;CZkk bbbb ssss sscc cccc cccc
Moldova;24;MDkk bbcc cccc cccc cccc cccc
Pakistan;24;PKkk bbbb cccc cccc cccc cccc
Romania;24;ROkk bbbb cccc cccc cccc cccc
Saudi Arabia;24;SAkk bbcc cccc cccc cccc cccc
Slovakia;24;SKkk bbbb ssss sscc cccc cccc
Spain;24;ESkk bbbb gggg xxcc cccc cccc
Sweden;24;SEkk bbbc cccc cccc cccc cccx
Tunisia;24;TNkk bbss sccc cccc cccc cccc
Virgin Islands;24;VGkk bbbb cccc cccc cccc cccc
Algeria;24;DZkk nnnn nnnn nnnn nnnn nnnn
Portugal;25;PTkk bbbb ssss cccc cccc cccx x
Angola;25;AOkk nnnn nnnn nnnn nnnn nnnn n
Cape Verde;25;CVkk nnnn nnnn nnnn nnnn nnnn n
Mozambique;25;MZkk nnnn nnnn nnnn nnnn nnnn n
Iceland;26;ISkk bbbb sscc cccc iiii iiii ii
Turkey;26;TRkk bbbb bxcc cccc cccc cccc cc
Iran;26;IRkk nnnn nnnn nnnn nnnn nnnn nn
France;27;FRkk bbbb bggg ggcc cccc cccc cxx
Greece;27;GRkk bbbs sssc cccc cccc cccc ccc
Italy;27;ITkk xaaa aabb bbbc cccc cccc ccc
Mauritania;27;MRkk bbbb bsss sscc cccc cccc cxx
Monaco;27;MCkk bbbb bsss sscc cccc cccc cxx
San Marino;27;SMkk xaaa aabb bbbc cccc cccc ccc
Burkina Faso;27;BFkk nnnn nnnn nnnn nnnn nnnn nnn
Cameroon;27;CMkk nnnn nnnn nnnn nnnn nnnn nnn
Madagascar;27;MGkk nnnn nnnn nnnn nnnn nnnn nnn
Albania;28;ALkk bbbs sssx cccc cccc cccc cccc
Azerbaijan;28;AZkk bbbb cccc cccc cccc cccc cccc
Cyprus;28;CYkk bbbs ssss cccc cccc cccc cccc
Dominican Republic;28;DOkk bbbb cccc cccc cccc cccc cccc
Guatemala;28;GTkk bbbb cccc cccc cccc cccc cccc
Hungary;28;HUkk bbbs sssk cccc cccc cccc cccx
Lebanon;28;LBkk bbbb cccc cccc cccc cccc cccc
Poland;28;PLkk bbbs sssx cccc cccc cccc cccc
Benin;28;BJkk annn nnnn nnnn nnnn nnnn nnnn
Ivory Coast;28;CIkk annn nnnn nnnn nnnn nnnn nnnn
Mali;28;MLkk annn nnnn nnnn nnnn nnnn nnnn
Senegal;28;SNkk annn nnnn nnnn nnnn nnnn nnnn
Brazil;29;BRkk bbbb bbbb ssss sccc cccc ccct n
Palestinian;29;PSkk bbbb xxxx xxxx xccc cccc cccc c
Qatar;29;QAkk bbbb cccc cccc cccc cccc cccc c
Ukraine;29;UAkk bbbb bbcc cccc cccc cccc cccc c
Jordan;30;JOkk bbbb nnnn cccc cccc cccc cccc cc
Kuwait;30;KWkk bbbb cccc cccc cccc cccc cccc cc
Mauritius;30;MUkk bbbb bbss cccc cccc cccc cccc cc
Malta;31;MTkk bbbb ssss sccc cccc cccc cccc ccc
Respuestas:
J (294 - 73.5 = 220.5)
No he contado la definición de la función (
f=:3 :0
...)
) porque puede considerarse repetitiva, contar todo el bloque da un puntaje de 304 - 76 = 228 .Pruebas:
Explicación:
b=.y-.' -.'
: elimina los separadores del argumento y almacena el resultado enb
.1}.;' '&,&.>_4<\b
: divídaseb
en grupos de cuatro, agregue un espacio delante de cada grupo, únase a los grupos y elimine el espacio inicial. Siy
contiene un número IBAN válido, esta es su representación canónica (es decir, grupos de cuatro, separados por espacios, y el último grupo puede tener menos de cuatro elementos).(
...){'Invalid';
: cree una matriz con la cadenaInvalid
como elemento 0 y el número IBAN formateado como elemento 1. Seleccione el correcto en función de si el número IBAN es válido:'NO.BEBI.---.JOKWU.MT.'
: una lista de todos los códigos de país para cada longitud, separados por puntos+/"1(2{.b)&E.;.2
: agrupe la cadena por los puntos y vea cuál contiene el código de país dado (los primeros 2 elementos deb
).15+1 i.~
: encuentra el índice de la coincidencia y suma15
para encontrar la longitud.(#b)=
: compárelo con la longitud real deb
.4|.b
: gireb
a la izquierda por 4 (reorganizar)k=.3&u:
: encuentra el valor ASCII para cada número48-~k-7*64<k
: resta 7 de cada letra, luego resta 48 de todos, dando los valores1".'x',~' '-.~":
: formatee, elimine espacios, agregue una 'x' al final (para el modo de alta precisión, que es necesario para números grandes) y vuelva a convertirlo en un número1=97|
: comprueba si el número mod 97 es igual a 1.>
: desempaquetar la cadena resultantefuente
CJam,
151.5141.75 puntosEl programa anterior tiene 189 bytes de longitud y califica para la bonificación.
Con un costo de 26 bytes más, para un puntaje total de 161.25, podemos evitar caracteres no imprimibles:
Puede probar esta versión en el intérprete de CJam .
Ejecución de ejemplo
Cómo funciona
convierte la cadena
"…"
en un número entero considerándola un número base 256, luego en una matriz de enteros considerándola un número base 27, agrega el código de caracteres@
a cada dígito y los convierte en caracteres en el proceso.Como resultado, se ejecuta el siguiente código:
fuente
LANG=en_US java -jar cjam-0.6.2.jar iban.cjam<<<GB82WEST12345698765432
salidas no válidas, ¿qué estoy haciendo mal (ejecutándose en Windows8.1 y Cygwin)?md5sum iban.cjam
debe imprimir1960c33e31ae5646cd0400826757b3bc
. 2. ¿Está la configuración regional instalada correctamente? Puede verificar ejecutandolocale -a | grep en_US
.fb620d509887f1a7298c3e5ff312401a
).locale -a|grep en_US
salidasen_US
yen_US.utf8
LANG=en_US cjam <(LANG=en_US cjam gen.cjam) <<< GB82WEST12345698765432
. He incluido una versión solo ASCII en mi respuesta que debería ser más fácil de verificar.Golpetazo,
738 519 444 434427Aquí hay algo para comenzar, lo escribí (y guardé 317 caracteres, principalmente en el bit de almacenamiento del código de país) mientras la pregunta estaba en el sandbox. Avíseme si hay algún problema.
La función se lee desde stdin, que es bastante común en Bash (la pregunta dice "acepta una cadena de caracteres alfanuméricos", no requiere que esto sea a través de argumentos).
Devuelve 0 si el IBAN es válido y un valor distinto de cero si no es válido.
Un IBAN que contiene caracteres distintos de los delimitadores
. -
yA-Z0-9
no es válido.Explicación
Ejemplos
fuente
Python 3 - (483 - 25%) 362
fuente
Perl (356 + 2 * 75% = 268.5)
el código es tan confuso que incluso el resaltado de sintaxis de SE se pierde en él :)
Explicación
-n
significa leer stdin línea por línea;-l
agrega nuevas líneas para imprimirrequerido para la operación de módulo más tarde para devolver el valor correcto.
eliminar todo lo que no sea \ w de IBAN.
convierta el número de iban a mayúsculas, también guárdelo en $ T; se usará para imprimir bonitas más tarde.
establezca la variable temporal en 15, se usará para construir una tabla hash con código de país para la asignación de longitud iban.
dividir la cadena grande en una matriz de comas o códigos de país de dos letras, iterar sobre ella. si el elemento comienza con una letra, es un código de país: guárdelo en el hash con un valor de $ q; de lo contrario, una coma significa incrementar $ q. entonces, NO obtendrá el valor de 15, BE y BI serán 16, y así sucesivamente.
coincide con los dos primeros caracteres de IBAN (el código del país)
compruebe si IBAN tiene la longitud correcta para el código de país, guarde el resultado en $ q
mover los primeros cuatro caracteres al final de IBAN
reemplazar todas las letras con los números correspondientes, comenzando con A = 10
imprima "Inválido" o el IBAN bonito impreso.
1==$_%97*$q
solo será igual1
para un IBAN con una longitud correcta y el resto correcto.fuente
perl
único" subconcurso ganas ;-) Aunque es confuso, ¿podrías intentar explicarlo un poco como en el ejemplo de bash? ¡¿Bastante por favor?! Si explicas el tuyo, explicaré el mío :-) (aunque podría robar uno de tus trucos reales en el país de longitudes IBAN primero). Salud.Perl 6 - 354 caracteres - (no estoy seguro de la bonificación)
Leer la entrada de
IBANS.txt
sobreSTDIN
y sorber las reglas del archivoir
(Salí de las reglas del total en caso de que fueran repetitivo - el archivo de reglas es de 191 caracteres por lo que el total sería de 545.IBANS.txt
es como sigue:Notas
wc -m ibanvalidate.p6
Salida típica:
Este no es el código típico de Perl6 (especialmente las
comb
líneas - un desarrollador de Perl amigable e influyente mencionó esto de pasada): Soy un principiante. Una vez que finalice el concurso, agregaré / cambiaré y haré las modificaciones sugeridas por Perl6-ers. Gracias por jugar y ser amable :-)fuente
Perl 6 , 311 bytes, puntaje 233.25
Pruébalo en línea!
no estoy seguro
Explicación
fuente
Python3.x (539 caracteres - 25% = 404.25)
(Para decir primero: estoy un poco confundido sobre lo que TIENE que contar con sus reglas, así que solo conté toda mi función)
539 caracteres - Incluyendo
import
ydef IBAN(i):
(las pestañas al comienzo de la línea se cuentan de todos modos en Python para que no importen)Bono aplicado según lo establecido en las reglas.
Código con comentarios (aún no completado ... Estoy demasiado cansado para escribir la parte restante de los comentarios ... Lo haré mañana)
fuente
Perl (535)
Realmente todavía no estoy jugando al golf, no tengo idea si califico para el bono ;-) Agregaré algunas explicaciones de tipo @professorfish.
fuente
JavaScript (Node.js) , 372 bytes * .75 = 279
Pruébalo en línea!
Casos de prueba tomados de la respuesta J de @marinus.
fuente