Uma prancha de Megachess


8

Você deseja criar um tabuleiro de xadrez quadrado. Os ladrilhos adjacentes devem alternar preto e branco como um tabuleiro de xadrez padrão, e o canto inferior esquerdo pode ser preto ou branco.

Seu programa terá dois números inteiros positivos, o número de preto e o número de ladrilhos brancos. Eles sempre serão menores que 1024. Você não precisa usar todos os blocos.

Saída do comprimento lateral máximo de um padrão de tabuleiro de xadrez que pode ser construído usando a quantidade fornecida de peças.

Casos de teste:

12, 15 -> 5
8, 8 -> 4    
4, 0 -> 1

Ei! Editei sua pergunta para dizer o que pensei que você queria dizer. Caso contrário, você pode editá-lo novamente. Bem-vindo ao PPCG!
CG One Handed

2
Penso que esta é uma boa pergunta, mas, infelizmente, mal afirmada. OP significa que, fornecendo a você alguns ladrilhos pretos e outros ladrilhos brancos (0 a 1000 para cada cor), descubra as dimensões do maior tabuleiro de xadrez que você pode criar. Casos de teste interessantes: Entrada [10,15] e Saída [ 4] e também Input [12,12] e Output [4]
J42161217 16/04/19

4
Você também postou esta semana passada , onde foi direcionado para a sandbox
xnor

8
O último caso de teste deve ser 1.
Nick Kennedy

2
@ SriotchilismO'Zaic, às vezes também aceitamos a solução mais curta em um idioma específico. "Melhor explicação", no entanto, não é um critério válido para aceitar uma solução.
Shaggy

Respostas:


10

JavaScript (ES7), 30 bytes

b=>w=>((b<w?b:w)*2|b!=w)**.5|0

Experimente online!

Dado o número de quadrados pretos b o número de quadrados brancos W , isso calcula:

s=2×min(b,W)+k
com:
k={0 0E se b=W1E se bW

Porque até tamanhos s , precisamos s2/2 quadrados de cada tipo (por exemplo, para s=8 : 32. quadrados pretos e 32. quadrados brancos).

Por estranho tamanhos s , precisamos s2/2 quadrados de um tipo e s2/2 quadrados de outro tipo (por exemplo, para s=5 : 12 quadrados pretos e 13 quadrados brancos, ou o inverso) . O parâmetro k é definido como 1 se mumax(b,W)mEun(b,W)+1, que representa esse quadrado extra de um lado.



5

Haskell , 35 bytes

x#y=floor$sqrt$min(x+y)$1+2*min x y

Experimente online!

Explicação

Esta resposta calcula a seguinte fórmula:

min(uma+b,2min(uma,b)+1)

Por que essa fórmula funciona? Bem, vamos começar observando o seguinte:

Cada quadrado de comprimento lateral uniforme pode ser revestido por ladrilhos 2×1 .

e

Cada quadrado de comprimento ímpar pode ser telhado, sobressalente um único 1×1 quadrado, por 2×1 telhas.

Agora, observamos que, se colocarmos esses ladrilhos 2×1 em um tabuleiro de xadrez, cada um ficaria no topo de um quadrado preto e no quadrado branco. Portanto, se fizermos um tabuleiro de xadrez uniforme, cada ladrilho precisa ter um par da outra cor, e se fizermos um tabuleiro de xadrez ímpar para cada ladrilho, mas um precisará de um par da outra cor. Isso nos diz que a resposta nunca é superior a 2min(uma,b)+1. 2min(uma,b)é o número máximo de pares que podemos fazer e a+1 é a última quadrado que does not' precisa de um par. O problema é que, seuma=b , não teremos o quadrado extra para o caso ímpar. Então, adicionamos outra condição: Nosso resultado não pode ser maior queuma+b. Ou seja, não podemos fazer um quadrado com mais peças do que as disponíveis.

Então, pegamos a menor das duas opções.

min(uma+b,2min(uma,b)+1)

Podemos notar que isso é o mesmo que a formulação de Arnauld, pois se uma=b então 2min(uma,b)uma+b


3

Ruby , 36 bytes

->x,y{'%i'%[x+y,x-~x,y-~y].min**0.5}

Experimente online!

x-~xé uma versão para golfe 2*x+1; estamos subtraindo a negação de dois complementos de x de si mesma. Depois disso, estou apenas usando a fórmula desta resposta , mas recolhendo os dois mins aninhados em um e, em seguida, usando a formatação de string para truncar para um número inteiro.


2

Retina 0.8.2 , 50 bytes

O#`\d+
\d+
$*
(1*),(1?\1)1*
$1$2
^(^1|11\1)*1*
$#1

Experimente online! O link inclui casos de teste. Explicação:

O#`\d+

Classifique os números em ordem crescente. Vamos chamá-los le h.

\d+
$*

Converta para unário.

(1*),(1?\1)1*
$1$2

Computar l + max(h, l + 1). Isso é equivalente a 2 * min(b, w) + (b != w). Veja a resposta de @ Arnauld para saber por que isso funciona.

^(^1|11\1)*1*
$#1

Encontre a raiz quadrada inteira mais alta.


2

05AB1E , 8 7 bytes

Ë≠+ß·tï

Experimente online ou verifique todos os casos de teste .

Exlação:

Usa uma derivada trivial da fórmula @Arnauld usada em sua resposta JavaScript para salvar um byte:

s=2×min(b+k,W+k)
k={0 0E se b=W1E se bW

Ë        # Check if the two values of the (implicit) input-pair are the same
         #  (1 if truthy; 0 if falsey)
        # Falsify (!= 1), so 1 becomes 0 and vice-versa
  +      # Add that to each of the (implicit) input-values
   ß     # Only leave the minimum of that
    ·    # Double it
     t   # Take the square root
      ï  # And truncate/floor it by casting to an integer

1

Japonês , 11 bytes

Solução JS do Porto de Arnauld. Recebe entrada como uma matriz.

ñÍÌÑ+Ur¦)¬f

Tente

ñÍÌÑ+Ur¦)¬f     :Implicit input of array U
ñ               :Sort by
 Í              :  Subtracting from 2
  Ì             :Last element (Yes, there are more straightforward ways of getting the minimum but I like this method and it doesn't cost any bytes)
   Ñ+           :Multiply by 2 and add
     Ur         :U reduced by
       ¦        :  Testing for inequality
        )       :End reduce
         ¬      :Square root
          f     :Floor



0

Japonês , 10 bytes

Solução JS do Porto de Arnauld.

mV Ñ|U¦V ¬

Experimente online!


Bem-vindo ao PPCG e bem-vindo ao Japt! :) Observe, porém, que você precisa aplicar o piso da raiz quadrada. Caso contrário, isso falhará 12, 12.
Salsicha
Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.