Você tem uma grade 3x3. Cada célula pode ser colorida em preto ou branco. Exiba todos os 512 desses corantes. Menos bytes ganha.
Você pode exibir as grades em qualquer formação, desde que sejam visualmente separadas e o espaçamento pareça regular. Você pode usar arte ou imagens ASCII. Quaisquer dois símbolos ou cores visíveis distintos podem ser usados para preto e branco. Qualquer espaço em branco é bom, desde que o resultado seja visualmente correto.
Exemplo de saída:
...
...
...
...
...
..X
...
...
.X.
...
...
.XX
...
...
X..
...
...
X.X
...
...
XX.
...
...
XXX
...
..X
...
...
..X
..X
...
..X
.X.
...
..X
.XX
...
..X
X..
...
..X
X.X
...
..X
XX.
...
..X
XXX
...
.X.
...
...
.X.
..X
...
.X.
.X.
...
.X.
.XX
...
.X.
X..
...
.X.
X.X
...
.X.
XX.
...
.X.
XXX
...
.XX
...
...
.XX
..X
...
.XX
.X.
...
.XX
.XX
...
.XX
X..
...
.XX
X.X
...
.XX
XX.
...
.XX
XXX
...
X..
...
...
X..
..X
...
X..
.X.
...
X..
.XX
...
X..
X..
...
X..
X.X
...
X..
XX.
...
X..
XXX
...
X.X
...
...
X.X
..X
...
X.X
.X.
...
X.X
.XX
...
X.X
X..
...
X.X
X.X
...
X.X
XX.
...
X.X
XXX
...
XX.
...
...
XX.
..X
...
XX.
.X.
...
XX.
.XX
...
XX.
X..
...
XX.
X.X
...
XX.
XX.
...
XX.
XXX
...
XXX
...
...
XXX
..X
...
XXX
.X.
...
XXX
.XX
...
XXX
X..
...
XXX
X.X
...
XXX
XX.
...
XXX
XXX
..X
...
...
..X
...
..X
..X
...
.X.
..X
...
.XX
..X
...
X..
..X
...
X.X
..X
...
XX.
..X
...
XXX
..X
..X
...
..X
..X
..X
..X
..X
.X.
..X
..X
.XX
..X
..X
X..
..X
..X
X.X
..X
..X
XX.
..X
..X
XXX
..X
.X.
...
..X
.X.
..X
..X
.X.
.X.
..X
.X.
.XX
..X
.X.
X..
..X
.X.
X.X
..X
.X.
XX.
..X
.X.
XXX
..X
.XX
...
..X
.XX
..X
..X
.XX
.X.
..X
.XX
.XX
..X
.XX
X..
..X
.XX
X.X
..X
.XX
XX.
..X
.XX
XXX
..X
X..
...
..X
X..
..X
..X
X..
.X.
..X
X..
.XX
..X
X..
X..
..X
X..
X.X
..X
X..
XX.
..X
X..
XXX
..X
X.X
...
..X
X.X
..X
..X
X.X
.X.
..X
X.X
.XX
..X
X.X
X..
..X
X.X
X.X
..X
X.X
XX.
..X
X.X
XXX
..X
XX.
...
..X
XX.
..X
..X
XX.
.X.
..X
XX.
.XX
..X
XX.
X..
..X
XX.
X.X
..X
XX.
XX.
..X
XX.
XXX
..X
XXX
...
..X
XXX
..X
..X
XXX
.X.
..X
XXX
.XX
..X
XXX
X..
..X
XXX
X.X
..X
XXX
XX.
..X
XXX
XXX
.X.
...
...
.X.
...
..X
.X.
...
.X.
.X.
...
.XX
.X.
...
X..
.X.
...
X.X
.X.
...
XX.
.X.
...
XXX
.X.
..X
...
.X.
..X
..X
.X.
..X
.X.
.X.
..X
.XX
.X.
..X
X..
.X.
..X
X.X
.X.
..X
XX.
.X.
..X
XXX
.X.
.X.
...
.X.
.X.
..X
.X.
.X.
.X.
.X.
.X.
.XX
.X.
.X.
X..
.X.
.X.
X.X
.X.
.X.
XX.
.X.
.X.
XXX
.X.
.XX
...
.X.
.XX
..X
.X.
.XX
.X.
.X.
.XX
.XX
.X.
.XX
X..
.X.
.XX
X.X
.X.
.XX
XX.
.X.
.XX
XXX
.X.
X..
...
.X.
X..
..X
.X.
X..
.X.
.X.
X..
.XX
.X.
X..
X..
.X.
X..
X.X
.X.
X..
XX.
.X.
X..
XXX
.X.
X.X
...
.X.
X.X
..X
.X.
X.X
.X.
.X.
X.X
.XX
.X.
X.X
X..
.X.
X.X
X.X
.X.
X.X
XX.
.X.
X.X
XXX
.X.
XX.
...
.X.
XX.
..X
.X.
XX.
.X.
.X.
XX.
.XX
.X.
XX.
X..
.X.
XX.
X.X
.X.
XX.
XX.
.X.
XX.
XXX
.X.
XXX
...
.X.
XXX
..X
.X.
XXX
.X.
.X.
XXX
.XX
.X.
XXX
X..
.X.
XXX
X.X
.X.
XXX
XX.
.X.
XXX
XXX
.XX
...
...
.XX
...
..X
.XX
...
.X.
.XX
...
.XX
.XX
...
X..
.XX
...
X.X
.XX
...
XX.
.XX
...
XXX
.XX
..X
...
.XX
..X
..X
.XX
..X
.X.
.XX
..X
.XX
.XX
..X
X..
.XX
..X
X.X
.XX
..X
XX.
.XX
..X
XXX
.XX
.X.
...
.XX
.X.
..X
.XX
.X.
.X.
.XX
.X.
.XX
.XX
.X.
X..
.XX
.X.
X.X
.XX
.X.
XX.
.XX
.X.
XXX
.XX
.XX
...
.XX
.XX
..X
.XX
.XX
.X.
.XX
.XX
.XX
.XX
.XX
X..
.XX
.XX
X.X
.XX
.XX
XX.
.XX
.XX
XXX
.XX
X..
...
.XX
X..
..X
.XX
X..
.X.
.XX
X..
.XX
.XX
X..
X..
.XX
X..
X.X
.XX
X..
XX.
.XX
X..
XXX
.XX
X.X
...
.XX
X.X
..X
.XX
X.X
.X.
.XX
X.X
.XX
.XX
X.X
X..
.XX
X.X
X.X
.XX
X.X
XX.
.XX
X.X
XXX
.XX
XX.
...
.XX
XX.
..X
.XX
XX.
.X.
.XX
XX.
.XX
.XX
XX.
X..
.XX
XX.
X.X
.XX
XX.
XX.
.XX
XX.
XXX
.XX
XXX
...
.XX
XXX
..X
.XX
XXX
.X.
.XX
XXX
.XX
.XX
XXX
X..
.XX
XXX
X.X
.XX
XXX
XX.
.XX
XXX
XXX
X..
...
...
X..
...
..X
X..
...
.X.
X..
...
.XX
X..
...
X..
X..
...
X.X
X..
...
XX.
X..
...
XXX
X..
..X
...
X..
..X
..X
X..
..X
.X.
X..
..X
.XX
X..
..X
X..
X..
..X
X.X
X..
..X
XX.
X..
..X
XXX
X..
.X.
...
X..
.X.
..X
X..
.X.
.X.
X..
.X.
.XX
X..
.X.
X..
X..
.X.
X.X
X..
.X.
XX.
X..
.X.
XXX
X..
.XX
...
X..
.XX
..X
X..
.XX
.X.
X..
.XX
.XX
X..
.XX
X..
X..
.XX
X.X
X..
.XX
XX.
X..
.XX
XXX
X..
X..
...
X..
X..
..X
X..
X..
.X.
X..
X..
.XX
X..
X..
X..
X..
X..
X.X
X..
X..
XX.
X..
X..
XXX
X..
X.X
...
X..
X.X
..X
X..
X.X
.X.
X..
X.X
.XX
X..
X.X
X..
X..
X.X
X.X
X..
X.X
XX.
X..
X.X
XXX
X..
XX.
...
X..
XX.
..X
X..
XX.
.X.
X..
XX.
.XX
X..
XX.
X..
X..
XX.
X.X
X..
XX.
XX.
X..
XX.
XXX
X..
XXX
...
X..
XXX
..X
X..
XXX
.X.
X..
XXX
.XX
X..
XXX
X..
X..
XXX
X.X
X..
XXX
XX.
X..
XXX
XXX
X.X
...
...
X.X
...
..X
X.X
...
.X.
X.X
...
.XX
X.X
...
X..
X.X
...
X.X
X.X
...
XX.
X.X
...
XXX
X.X
..X
...
X.X
..X
..X
X.X
..X
.X.
X.X
..X
.XX
X.X
..X
X..
X.X
..X
X.X
X.X
..X
XX.
X.X
..X
XXX
X.X
.X.
...
X.X
.X.
..X
X.X
.X.
.X.
X.X
.X.
.XX
X.X
.X.
X..
X.X
.X.
X.X
X.X
.X.
XX.
X.X
.X.
XXX
X.X
.XX
...
X.X
.XX
..X
X.X
.XX
.X.
X.X
.XX
.XX
X.X
.XX
X..
X.X
.XX
X.X
X.X
.XX
XX.
X.X
.XX
XXX
X.X
X..
...
X.X
X..
..X
X.X
X..
.X.
X.X
X..
.XX
X.X
X..
X..
X.X
X..
X.X
X.X
X..
XX.
X.X
X..
XXX
X.X
X.X
...
X.X
X.X
..X
X.X
X.X
.X.
X.X
X.X
.XX
X.X
X.X
X..
X.X
X.X
X.X
X.X
X.X
XX.
X.X
X.X
XXX
X.X
XX.
...
X.X
XX.
..X
X.X
XX.
.X.
X.X
XX.
.XX
X.X
XX.
X..
X.X
XX.
X.X
X.X
XX.
XX.
X.X
XX.
XXX
X.X
XXX
...
X.X
XXX
..X
X.X
XXX
.X.
X.X
XXX
.XX
X.X
XXX
X..
X.X
XXX
X.X
X.X
XXX
XX.
X.X
XXX
XXX
XX.
...
...
XX.
...
..X
XX.
...
.X.
XX.
...
.XX
XX.
...
X..
XX.
...
X.X
XX.
...
XX.
XX.
...
XXX
XX.
..X
...
XX.
..X
..X
XX.
..X
.X.
XX.
..X
.XX
XX.
..X
X..
XX.
..X
X.X
XX.
..X
XX.
XX.
..X
XXX
XX.
.X.
...
XX.
.X.
..X
XX.
.X.
.X.
XX.
.X.
.XX
XX.
.X.
X..
XX.
.X.
X.X
XX.
.X.
XX.
XX.
.X.
XXX
XX.
.XX
...
XX.
.XX
..X
XX.
.XX
.X.
XX.
.XX
.XX
XX.
.XX
X..
XX.
.XX
X.X
XX.
.XX
XX.
XX.
.XX
XXX
XX.
X..
...
XX.
X..
..X
XX.
X..
.X.
XX.
X..
.XX
XX.
X..
X..
XX.
X..
X.X
XX.
X..
XX.
XX.
X..
XXX
XX.
X.X
...
XX.
X.X
..X
XX.
X.X
.X.
XX.
X.X
.XX
XX.
X.X
X..
XX.
X.X
X.X
XX.
X.X
XX.
XX.
X.X
XXX
XX.
XX.
...
XX.
XX.
..X
XX.
XX.
.X.
XX.
XX.
.XX
XX.
XX.
X..
XX.
XX.
X.X
XX.
XX.
XX.
XX.
XX.
XXX
XX.
XXX
...
XX.
XXX
..X
XX.
XXX
.X.
XX.
XXX
.XX
XX.
XXX
X..
XX.
XXX
X.X
XX.
XXX
XX.
XX.
XXX
XXX
XXX
...
...
XXX
...
..X
XXX
...
.X.
XXX
...
.XX
XXX
...
X..
XXX
...
X.X
XXX
...
XX.
XXX
...
XXX
XXX
..X
...
XXX
..X
..X
XXX
..X
.X.
XXX
..X
.XX
XXX
..X
X..
XXX
..X
X.X
XXX
..X
XX.
XXX
..X
XXX
XXX
.X.
...
XXX
.X.
..X
XXX
.X.
.X.
XXX
.X.
.XX
XXX
.X.
X..
XXX
.X.
X.X
XXX
.X.
XX.
XXX
.X.
XXX
XXX
.XX
...
XXX
.XX
..X
XXX
.XX
.X.
XXX
.XX
.XX
XXX
.XX
X..
XXX
.XX
X.X
XXX
.XX
XX.
XXX
.XX
XXX
XXX
X..
...
XXX
X..
..X
XXX
X..
.X.
XXX
X..
.XX
XXX
X..
X..
XXX
X..
X.X
XXX
X..
XX.
XXX
X..
XXX
XXX
X.X
...
XXX
X.X
..X
XXX
X.X
.X.
XXX
X.X
.XX
XXX
X.X
X..
XXX
X.X
X.X
XXX
X.X
XX.
XXX
X.X
XXX
XXX
XX.
...
XXX
XX.
..X
XXX
XX.
.X.
XXX
XX.
.XX
XXX
XX.
X..
XXX
XX.
X.X
XXX
XX.
XX.
XXX
XX.
XXX
XXX
XXX
...
XXX
XXX
..X
XXX
XXX
.X.
XXX
XXX
.XX
XXX
XXX
X..
XXX
XXX
X.X
XXX
XXX
XX.
XXX
XXX
XXX
code-golf
ascii-art
graphical-output
combinatorics
grid
Filipe Teixeira
fonte
fonte
1
s e0
s são substituídos porX
e.
Respostas:
K, 11 bytes
Exemplo de saída:
Esta é a representação nativa impressa de K de uma lista de matrizes, que eu acho que é suficiente para a especificação do problema. Cada matriz é delimitada por um conjunto de parênteses.
E uma rápida verificação de sanidade para demonstrar que 512 matrizes são construídas:
Muito simples. A maior parte do trabalho está no
!
. Primeiro, geramos um vetor 9s longo de 9 segundos usando "take" (9#2
). Então, usamos a forma monádica "odômetro" de!
- alguns exemplos ilustram seu comportamento:Em seguida, faça uma reformulação 3x3 (
(3 3#)
) de cada ('
) dos vetores 0/1 de 9 comprimentos.fonte
Mathematica, 25 bytes
Dá uma matriz com todas as grades como imagens, que também é exibida diretamente na tela:
(Cortado para não explodir a publicação desnecessariamente.)
fonte
JavaScript, 77
80Revisado após a revisão do PO. Agora temos uma pergunta, então aqui está uma resposta.
Execute o snippet em qualquer navegador para testar.
Post antigo: exibição gráfica em um navegador, com javascript e canvas. ~ 300 bytes de código (pode ser reduzido).
Execute o snippet abaixo.
fonte
(ES6)
, você pode substituir.join('\n')
com .join` `(nova linha literal, não espaço ... estúpido comentário formatação) para salvar 3 bytesMatlab, 33
Foi meio complicado conseguir as dimensões corretas, mas estou muito feliz com o resultado!
fonte
POWERSHELL - 65
resultado
confirmação
edição inspirada na exibição de resultados da resposta do mathematica-617
fonte
Python 2, 49 bytes
Divida a expansão binária de
i
. Os valores binários de comprimento-10 512 a 1023 são usados, cortando o 1 inicial (e o prefixo0b
). Estes são divididos em blocos de 3, como janelas[3:6]
,[6:9]
,[9:12]
, e[12:15]
, com o último em branco para fazer uma linha em branco. A iteração sobre as quatro fatias é reduzida com o loop externo da contagem de 512 números com o truque divmod.fonte
CJam, 12 bytes
Teste aqui.
Usa
0
e1
como os caracteres distintos.Explicação
Uma solução alternativa (ainda com 12 bytes) é
fonte
Ruby, 86 bytes
O meu é impresso com aspas porque
p
é mais curto queputs
, mas ainda se encaixa nas regras.fonte
Haskell,
5754 bytesf
dá a mesma saída que na descrição do desafio, ou seja, começa comEdit: @Mauris encontrou 3 bytes para salvar. Obrigado!
fonte
r x=sequence[x,x,x]
faz a mesma coisa e é mais curto.C # - 111
Converte todos os int em sua representação binária e divide a cada 3 caracteres.
fonte
Python 2, 95 bytes
Caracteres distintos são
0
e1
, cada bloco é separado por\n\n
.fonte
Python 2, 81
fonte
Ruby, 92 bytes
Conta em se
0
es1
, e cada bloco é separado por uma linha vazia (\n\n
)fonte
Ruby, 68 bytes
Imprime exatamente a mesma saída que o exemplo fornecido na pergunta
fonte
tr
saída0
e1
está bem. Mais algumas sugestões512.times{|i|$><<("%09b"%i).gsub(/.../){$&+$/}+$/}
50 bytes.Python 3, 80 bytes
Eu consegui superar alguém :)
fonte
i=512
newlinewhile i:print("\n".join(format(i,'09b')[j:j+3]for j in(0,3,6)),"\n");i-=1
PHP, 55 bytes
usa
0
e1
. Corra com-r
.fonte
Pitão, 11 bytes
Experimente aqui!
Obrigado @Jakube :)
fonte
Python 2 , 56 bytes
Experimente online!
Retorna as 512 configurações como um objeto definido em python. Consulte a versão ungolfed para tornar a saída mais legível.
Versão Ungolfed para tornar a saída mais legível:
Python 2 , 121 bytes
Experimente online!
fonte
C - 97 bytes
Imprime basicamente o exemplo de saída da pergunta original.
fonte
Swift 2, 92 bytes
A string int para binária no Swift ocupa muitos caracteres, então eu apenas uso dois loops aninhados ...
fonte
Prolog (SWI), 98 bytes
Saída é uma lista de matrizes 3x3 que contêm os elementos 0 e 1.
Intérprete online
Eu sinto que a geração da matriz poderia ser mais curta.
Deveria ser possível ajustar o intervalo em um forall ou algo semelhante, mas não consigo descobrir como.
Dicas de golfe apreciadas.
fonte
Perl,
5655 bytesSaída:
fonte
Python 3,
123121109103 bytesAqui está o meu antigo:
E aqui está o meu novo:
Isso imprime caracteres extras, mas o OP disse que a arte ASCII é permitida, o que implica que vários caracteres estão corretos.
fonte
Python 3, 74 bytes
Apenas um pouco menor do que a resposta do Destructible Lemon
fonte
Perl, 52 bytes
ou 54 bytes:
ou Perl 5.14+, 48 bytes:
fonte
Gelatina , 17 bytes (não concorrente)
Experimente online!
Usos
01
. Por causa de um bug⁾
, eu tive que usar em“¶¶
vez de⁾¶¶
, porque senão em vez de duas novas linhas, dois pilgrows apareceriam na saída. Como você pode ver, porém, isso não me custou nenhum bytes.K supera isso, então isso deve ser ainda mais desenvolvido.
fonte
05AB1E , 15 bytes (não concorrente)
Experimente online!
fonte
J , 27 bytes
Experimente online!
fonte
echo _3]\"1#:i.512
.Tcl , 72 bytes
Experimente online!
fonte
Python 2 , 114 bytes
Experimente online!
fonte