Você está cansado de outros jogadores anunciarem presunçosamente "BINGO" e passarem triunfantemente por você para reivindicar o prêmio. Desta vez será diferente. Você subornou o chamador para fazer as chamadas do BINGO com antecedência, na ordem em que serão chamadas. Agora você só precisa criar um quadro BINGO que vencerá o mais cedo possível para essas chamadas, garantindo uma vitória (ou um empate improvável).
Dada uma sequência ou lista delimitada de chamadas em ordem, no formato típico do BINGO (letras incluídas, por exemplo, B9
ou G68
consulte as regras para obter mais informações), produza uma matriz ou lista 2D representando uma placa BINGO ideal para essas chamadas. Suponha que a entrada sempre será válida.
Regras do BINGO:
- Placa 5x5
- Um "BINGO" é quando o seu cartão tem 5 números seguidos dos números que foram chamados até agora.
- O quadrado central é livre (contado automaticamente para um BINGO) e pode ser representado por espaços em branco, por uma lista vazia
-1
ou por0
. - As colunas 5 são representados pelas letras
B
,I
,N
,G
,O
, respectivamente. - A primeira coluna pode conter os números 1 a 15, a segunda 16 a 30, ... e a quinta a 61 a 75.
- As letras e números utilizados para entrada podem opcionalmente ser delimitados (por algo que faça sentido, como um
,
ou espaço) ou tomados como uma tupla de um caractere e um número. - A saída requer apenas números em cada local da matriz.
- Os quadrados que não contribuem para o seu BINGO inicial devem ser válidos, mas não precisam ser ótimos.
- Este é o código-golfe, o código mais curto vence
Exemplos:
Estou usando esse formato de entrada para os exemplos, porque é mais curto. Veja a seção acima para formatos aceitáveis de entrada / saída.
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.