Sie haben es satt, dass andere Spieler selbstgefällig "BINGO" ankündigen und triumphierend an Ihnen vorbei gehen, um ihren Preis zu gewinnen. Diesmal wird es anders sein. Sie haben den Anrufer bestochen, um Ihnen die BINGO- Anrufe im Voraus in der Reihenfolge zu übermitteln , in der sie angerufen werden. Jetzt müssen Sie nur noch ein BINGO-Board erstellen, das für diese Calls so früh wie möglich gewinnt und Ihnen einen Gewinn (oder ein unwahrscheinliches Unentschieden) garantiert.
Wenn eine durch Trennzeichen getrennte Zeichenfolge oder Liste der Anrufe in der angegebenen Reihenfolge im typischen BINGO-Format (Buchstaben enthalten, z. B. B9oder G68siehe die Regeln für weitere Informationen) angegeben ist, wird eine Matrix oder 2D-Liste ausgegeben, die eine optimale BINGO-Karte für diese Anrufe darstellt. Angenommen, die Eingabe ist immer gültig.
BINGO-Regeln:
- 5x5 board
- Ein "Bingo" ist, wenn Ihre Karte 5 Nummern in einer Reihe von den Nummern hat, die bisher angerufen wurden.
- Das mittlere Quadrat ist frei (wird automatisch zu einem BINGO gezählt) und kann durch Leerzeichen, eine leere Liste
-1oder dargestellt werden0. - Die 5 Spalten sind durch die Buchstaben
B,I,N,G,O, respectively. - Die erste Spalte kann die Nummern 1-15, die zweite 16-30, ... und die fünfte 61-75 enthalten.
- Die für die Eingabe verwendeten Buchstaben und Zahlen können optional (durch ein sinnvolles
,Zeichen wie a oder ein Leerzeichen) oder als Tupel aus einem Zeichen und einer Zahl abgegrenzt werden . - Die Ausgabe erfordert nur Zahlen an jeder Stelle in der Matrix.
- Quadrate, die nicht zu Ihrem frühen BINGO beitragen, müssen gültig sein, müssen aber nicht optimal sein.
- Das ist Code-Golf, der kürzeste Code gewinnt
Beispiele:
Ich verwende dieses Eingabeformat für die Beispiele, weil es kürzer ist. Im obigen Abschnitt finden Sie akzeptable Eingabe- / Ausgabeformate.
O61 B2 N36 G47 I16 N35 I21 O64 G48 O73 I30 N33 I17 N43 G46 O72 I19 O71 B14 B7 G50 B1 I22 B8 N40 B13 B6 N37 O70 G55 G58 G52 B3 B4 N34 I28 I29 O65 B11 G51 I23 G56 G59 I27 I25 G54 O66 N45 O67 O75 N42 O62 N31 N38 N41 G57 N39 B9 G60 I20 N32 B15 O63 N44 B10 I26 O68 G53 I18 B12 O69 G49 B5 O74 I24
Possible Output (this has a horizontal BINGO in 3rd row. A diagonal is also possible.):
[[11,25,42,53,68],
[ 6,22,32,57,62],
[ 2,16, 0,47,61],
[ 3,17,37,59,75],
[ 9,19,41,46,70]]
N42 N34 O66 N40 B6 O65 O63 N41 B3 G54 N45 I16 O67 N31 I28 B2 B14 G51 N36 N33 I23 B11 I17 I27 N44 I24 O75 N38 G50 G58 B12 O62 I18 B5 O74 G60 I26 B8 I22 N35 B1 B4 G53 O73 G52 O68 B10 O70 I30 G59 N43 N39 B9 G46 G55 O64 O61 I29 G56 G48 G49 I19 G57 N37 O72 I25 N32 B13 B7 B15 O71 I21 I20 O69 G47
Must be a vertical BINGO in 3rd (N) column (because 4 N's came before one of each B,I,G,O):
[[11,25,42,53,63],
[ 2,22,34,57,65],
[ 6,16, 0,47,66],
[ 3,17,41,54,75],
[ 9,19,40,46,70]]
The 5 columns are represented by the letters B,I,N,G,O, respectively.