Schreiben Sie ein Programm (der Hauptteil der Funktion reicht aus), das eine Zeichenfolge alphanumerischer Zeichen akzeptiert und gemäß ISO 13616: 2007 validiert. Der Validierungsalgorithmus lautet (Quelle: Wikipedia-Artikel auf IBAN http://en.wikipedia.org/wiki/International_Bank_Account_Number ):
Validierung der IBAN Eine IBAN wird validiert, indem sie in eine Ganzzahl konvertiert und eine grundlegende Mod-97-Operation (wie in ISO 7064 beschrieben) ausgeführt wird. Wenn die IBAN gültig ist, ist der Rest gleich 1. Der Algorithmus der IBAN-Validierung lautet wie folgt:
- Überprüfen Sie, ob die gesamte IBAN-Länge je nach Land korrekt ist. Wenn nicht, ist die IBAN ungültig. Die korrekten IBAN-Längen finden Sie hier: http://pastebin.com/kp4eECVk ( siehe auch unten), sortiert nach der Länge der IBAN-Nummer. Die ersten 2 Zeichen jeder Nummer sind die Landesvorwahl. Alle anderen Zeichen (Kleinbuchstaben auf dem Pastebin, können aber in der tatsächlichen IBAN beliebig sein) hinter den ersten 2 können beliebige alphanumerische Zeichen sein.
- Verschieben Sie die vier Anfangszeichen an das Ende der Zeichenfolge.
- Ersetzen Sie jeden Buchstaben in der Zeichenfolge durch zwei Ziffern, wodurch die Zeichenfolge erweitert wird, wobei A = 10, B = 11, ..., Z = 35.
- Interpretieren Sie die Zeichenfolge als Dezimalzahl und berechnen Sie den Rest dieser Zahl bei Division durch 97
Wenn der Rest 1 ist, ist der Prüfziffertest bestanden und die IBAN ist möglicherweise gültig.
Beispiel (fiktive Bank in Großbritannien, Bankleitzahl 12-34-56, Kontonummer 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
Der Algorithmus kann true (oder einen wahrheitsgemäßen Wert) zurückgeben, wenn die Zahl gültig ist, und false (oder einen falschen Wert), wenn die Zahl gemäß dem Algorithmus ungültig ist. Sie müssen nicht überprüfen, ob die Nummer tatsächlich vorhanden ist, sondern nur, wenn sie gültig ist. Der Algorithmus muss für jede der verschiedenen genehmigten IBAN-Nummern funktionieren, die im obigen Wikipedia-Artikel erwähnt werden. Der Algorithmus sollte mit Zahlen mit oder ohne Trennzeichen zwischen zwei alphanumerischen Zeichen kompatibel sein. Das Trennzeichen kann entweder Punkte, Leerzeichen oder Bindestriche sein, und eine Zahl kann verschiedene Arten von Trennzeichen enthalten.
Es gelten die üblichen Lücken: keine externen Ressourcen, keine integrierten Funktionen oder Methoden.
Der Puzzletyp ist Code Golf. Der kürzeste Code in Bytecount gewinnt. Das zur Ausführung des Programms erforderliche Standard-Boilerplate (z. B. Namespace, Klasse, Funktionsdeklaration in OOP) ist nicht in der Anzahl der Bytes enthalten.
Bonus: Wenn Sie die korrekt formatierte IBAN-Nummer (gemäß dem nationalen Format auf Wikipedia) anstelle von true im Fall einer gültigen Nummer zurückgeben können, erhalten Sie eine 25% ige Reduzierung Ihrer Punktzahl. Wenn die Zahl ungültig ist, geben Sie eine Literalzeichenfolge mit dem Wert "Ungültig" zurück.
Kopie der IBAN-Längen für den Fall, dass der Pastebin jemals entfernt wird:
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
Antworten:
J (294 - 73,5 = 220,5)
Ich habe die Funktionsdefinition (
f=:3 :0
...)
) nicht gezählt, da sie als Boilerplate betrachtet werden kann. Das Zählen des gesamten Blocks ergibt eine Punktzahl von 304 - 76 = 228 .Tests:
Erläuterung:
b=.y-.' -.'
: Entfernen Sie alle Trennzeichen aus dem Argument und speichern Sie das Ergebnis inb
.1}.;' '&,&.>_4<\b
:b
In Vierergruppen aufteilen, vor jeder Gruppe ein Leerzeichen einfügen, den Gruppen beitreten und das führende Leerzeichen entfernen. Wenny
eine gültige IBAN-Nummer enthalten ist, ist dies ihre kanonische Darstellung (dh Vierergruppen, durch Leerzeichen getrennt, wobei die letzte Gruppe möglicherweise weniger als vier Elemente enthält).(
...){'Invalid';
: Erstellen Sie ein Array mit der ZeichenfolgeInvalid
als Element 0 und der formatierten IBAN-Nummer als Element 1. Wählen Sie die richtige aus, je nachdem, ob die IBAN-Nummer gültig ist:'NO.BEBI.---.JOKWU.MT.'
: Eine Liste aller Ländercodes für jede Länge, getrennt durch Punkte+/"1(2{.b)&E.;.2
: Gruppieren Sie die Zeichenfolge nach den Punkten und sehen Sie, welche den angegebenen Ländercode enthält (die ersten beiden Elemente vonb
).15+1 i.~
: Finden Sie den Index des passenden und fügen Sie ihn hinzu15
, um die Länge zu ermitteln.(#b)=
: Überprüfen Sie es mit der tatsächlichen Länge vonb
.4|.b
: umb
4 nach links drehen (neu anordnen)k=.3&u:
: Finden Sie den ASCII-Wert für jede Nummer48-~k-7*64<k
: subtrahieren Sie 7 von jedem Buchstaben, dann subtrahieren Sie 48 von allen und geben Sie die Werte an1".'x',~' '-.~":
: formatieren, Leerzeichen entfernen, am Ende ein 'x' hinzufügen (für den hochpräzisen Modus, der für große Zahlen erforderlich ist) und wieder in eine Zahl umwandeln1=97|
: überprüfe ob die Zahl mod 97 gleich 1 ist.>
: Entpacken Sie die resultierende Zeichenfolgequelle
CJam,
151,5141,75 PunkteDas obige Programm ist 189 Bytes lang und qualifiziert sich für den Bonus.
Auf Kosten von 26 weiteren Bytes - bei einer Gesamtpunktzahl von 161,25 - können wir nicht druckbare Zeichen vermeiden:
Sie können diese Version im CJam-Interpreter testen .
Beispiellauf
Wie es funktioniert
konvertiert die Zeichenfolge
"…"
in eine Ganzzahl, indem sie als Basis-256-Zahl betrachtet wird, und dann in ein Array von Ganzzahlen, indem sie als Basis-27-Zahl betrachtet wird, fügt den Zeichencode@
jeder Ziffer hinzu und wandelt sie dabei in Zeichen um.Infolgedessen wird der folgende Code ausgeführt:
quelle
LANG=en_US java -jar cjam-0.6.2.jar iban.cjam<<<GB82WEST12345698765432
Ausgaben Ungültig, was mache ich falsch (unter Windows 8.1 und Cygwin)?md5sum iban.cjam
sollte drucken1960c33e31ae5646cd0400826757b3bc
. 2. Ist das Gebietsschema ordnungsgemäß installiert? Sie können dies durch Ausführen überprüfenlocale -a | grep en_US
.fb620d509887f1a7298c3e5ff312401a
).locale -a|grep en_US
Ausgängeen_US
unden_US.utf8
LANG=en_US cjam <(LANG=en_US cjam gen.cjam) <<< GB82WEST12345698765432
. Ich habe meiner Antwort eine Nur-ASCII-Version hinzugefügt, die leichter zu überprüfen sein sollte.Bash,
738 519 444 434427Hier ist etwas, um uns anzufangen, ich habe es geschrieben (und 317 Zeichen gespeichert, hauptsächlich im Speichercode-Bit des Ländercodes), während sich die Frage in der Sandbox befand. Lassen Sie mich wissen, wenn es irgendwelche Probleme gibt.
Die Funktion liest aus stdin, was in Bash durchaus üblich ist (die Frage lautet "Akzeptiert eine Zeichenfolge alphanumerischer Zeichen", dies muss nicht über Argumente erfolgen).
Es gibt 0 zurück, wenn die IBAN gültig ist, und einen Wert ungleich Null, wenn sie ungültig ist.
Eine IBAN, die andere Zeichen als die Trennzeichen enthält
. -
undA-Z0-9
ungültig istErläuterung
Beispiele
quelle
Python 3 - (483 - 25%) 362
quelle
Perl (356 + 2 * 75% = 268,5)
Der Code ist so verwirrend, dass sogar die Syntaxhervorhebung von SE darin verloren geht :)
Erläuterung
-n
bedeutet, stdin Zeile für Zeile zu lesen;-l
Fügt neue Zeilen zum Drucken hinzuErforderlich für den Modulo-Betrieb später, um den korrekten Wert zurückzugeben.
Entfernen Sie alles, was nicht \ w ist, aus IBAN.
Konvertieren Sie die iban-Nummer in Großbuchstaben und speichern Sie sie in $ T. - wird später zum hübschen Drucken verwendet.
Setzen Sie die temporäre Variable auf 15. Sie wird verwendet, um eine Hash-Tabelle mit Ländercode für die Zuordnung der Iban-Länge zu erstellen.
Teilen Sie die große Zeichenfolge in ein Array von Kommas oder aus zwei Buchstaben bestehenden Ländercodes auf und wiederholen Sie den Vorgang. Wenn das Element mit einem Buchstaben beginnt, handelt es sich um einen Ländercode. Speichern Sie ihn im Hash mit einem Wert von $ q. Andernfalls bedeutet ein Komma, $ q zu erhöhen. NO erhält also den Wert 15, BE und BI den Wert 16 und so weiter.
stimmen mit den ersten beiden Zeichen von IBAN überein (der Ländercode)
Überprüfen Sie, ob IBAN die richtige Länge für den Ländercode hat. Speichern Sie das Ergebnis in $ q
Verschieben Sie die ersten vier Zeichen an das Ende von IBAN
Ersetzen Sie alle Buchstaben durch entsprechende Zahlen, beginnend mit A = 10
Drucken Sie entweder "Ungültig" oder die hübsch gedruckte IBAN.
1==$_%97*$q
wird nur1
für eine IBAN mit einer korrekten Länge und einem korrekten Rest gleich sein.quelle
perl
einzigen" Subwettbewerb gewinnen Sie ;-) Auch wenn es verwirrend ist, können Sie versuchen , es ein wenig wie im Bash-Beispiel zu erklären? Bitte schön?! Wenn du deine erklärst, erkläre ich meine :-) (obwohl ich vielleicht zuerst einen deiner Tricks aus dem IBAN-Längenland stehlen würde). Prost.Perl 6 - 354 Zeichen - (Bonus nicht sicher)
Lesen von Eingaben von
IBANS.txt
onSTDIN
und Schlürfen der Regeln aus der Dateiir
(ich habe die Regeln aus der Summe herausgelassen, falls sie Boilerplate waren - die Regeldatei besteht aus 191 Zeichen, sodass die Summe 545 wäre.IBANS.txt
ist wie folgt:Anmerkungen
wc -m ibanvalidate.p6
Typische Ausgabe:
Dies ist kein typischer Perl6-Code (insbesondere die
comb
Zeilen, die ein freundlicher und einflussreicher Perl-Entwickler im Vorbeigehen erwähnt hat): Ich bin ein Anfänger. Sobald der Wettbewerb beendet ist, werde ich alle von Perl6-er vorgeschlagenen Änderungen hinzufügen / ändern und vornehmen. Danke fürs Spielen und nett sein :-)quelle
Perl 6 , 311 Bytes, Punktzahl 233,25
Probieren Sie es online aus!
ich bin mir nicht sicher
Erläuterung
quelle
Python3.x (539 Zeichen - 25% = 404,25)
(Um zuerst gesagt zu werden: Ich bin ein bisschen verwirrt, was nach Ihren Regeln zu zählen ist, also habe ich nur meine gesamte Funktion gezählt.)
539 Zeichen - Einschließlich
import
unddef IBAN(i):
(Tabulatoren am Anfang der Zeile werden in Python trotzdem gezählt, sodass sie keine Rolle spielen)Der Bonus wird wie in den Regeln angegeben angewendet.
Code mit Kommentaren (noch nicht abgeschlossen ... Ich bin viel zu müde, um den restlichen Teil der Kommentare zu schreiben ... das mache ich morgen)
quelle
Perl (535)
Noch nicht wirklich Golf gespielt - keine Ahnung, ob ich mich für den Bonus qualifiziere ;-) Ich werde einige Erklärungen zum Typ @professorfish hinzufügen.
quelle
JavaScript (Node.js) , 372 Byte * .75 = 279
Probieren Sie es online aus!
Testfälle aus @marinus 'J-Antwort entlehnt.
quelle