Qual número grande é maior?

22

Entrada

Inteiros a1, a2, a3, b1, b2, b3, cada um no intervalo de 1 a 20.

Saída

True if a1^(a2^a3) > b1^(b2^b3) and False otherwise.

^ é exponenciação nesta questão.

Regras

Isso é código-golfe. Seu código deve terminar corretamente em 10 segundos para qualquer entrada válida em um PC de mesa padrão.

Você pode produzir qualquer coisa Truthy for True e qualquer coisa Falsey for False.

Você pode assumir qualquer ordem de entrada que desejar, desde que especificada na resposta e sempre a mesma.

Para esta pergunta, seu código deve estar sempre correto. Ou seja, não deve falhar devido a imprecisões de ponto flutuante. Devido ao alcance limitado da entrada, isso não deve ser muito difícil de alcançar.

Casos de teste

3^(4^5) > 5^(4^3)
1^(2^3) < 3^(2^1)
3^(6^5) < 5^(20^3)
20^(20^20) > 20^(20^19)
20^(20^20) == 20^(20^20)
2^2^20 > 2^20^2
2^3^12 == 8^3^11
1^20^20 == 1^1^1
1^1^1 == 1^20^20
Anush
fonte
Comentários não são para discussão prolongada; esta conversa foi movida para o bate-papo .
DJMcMayhem

Respostas:

16

Perl 6 , 31 29 bytes

-2 bytes graças ao Grimy

*.log10* * ***>*.log10* * ***

Experimente online!

Acredite ou não, isso é não um esolang, mesmo que seja composto principalmente de asteriscos. Isso usa a fórmula de Arnauld , com log10 em vez de ln.

Brincadeira
fonte
Eu acredito que isso falha 2^3^12 == 8^3^11.
Ørjan Johansen 26/04
@ ØrjanJohansen Isso deve ser corrigido agora. deixe-me saber se falhar para mais alguma coisa
Jo King
@ Grimy Thanks! Eu poderia jurar que tentei isso ...
Jo King
7

R , 39 bytes

function(x,y,z)rank(log2(x)*(y^z))[1]<2

Experimente online!

Retorna FALSE quando a > be VERDADEIRO seb < a

digEmAll
fonte
4
Isso é errado paraf(2,2,20,2,20,2)
H.PWiz
Corrigido, usando sua sugestão para a resposta @Arnauld;)
digEmAll 25/04
Eu acredito que isso falha 2^3^12 == 8^3^11.
Ørjan Johansen 26/04
1
Falha para ambos 1^20^20 == 1^1^1e 1^1^1 == 1^20^20.
Olivier Grégoire
6

05AB1E , 11 9 11 7 bytes

.²Šm*`›

Porto de @Arnauld 's JavaScript e @Arnauld R do @digEmAll (eu os vi postando na mesma época)
-2 bytes graças a @Emigna
+2 bytes como correção de bugs após as respostas de @Arnauld e @digEmAll contidas um erro
-4 bytes agora que uma ordem de entrada diferente é permitida apósos comentários de @LuisMendo

De entrada como [a1,b1], [a3,b3], [a2,b2]como três entradas separadas.

Experimente online ou verifique todos os casos de teste .

Explicação:

       # Take the logarithm with base 2 of the implicit [a1,b1]-input
  Š      # Triple-swap a,b,c to c,a,b with the implicit inputs
         #  The stack order is now: [log2(a1),log2(b1)], [a2,b2], [a3,b3]
   m     # Take the power, resulting in [a2**a3,b2**b3]
    *    # Multiply it with the log2-list, resulting in [log2(a1)*a2**a3,log2(b1)*b2**b3]
     `   # Push both values separated to the stack
        # And check if log2(a1)*a2**a3 is larger than log2(b1)*b2**b3
         # (after which the result is output implicitly)
Kevin Cruijssen
fonte
1
Sua
Emigna
@ Emigna Ah bom, eu estava olhando para uma abordagem com ć, mas esqueci completamente de usar š(não sei por que agora que eu vejo isso, haha). Obrigado!
Kevin Cruijssen em 25/04
Isso parece estar incorreto (porque a resposta de Arnauld estava incorreta até a correção recente).
Anush em 25/04
@Anush Corrigido e 4 bytes salvos, levando as entradas em uma ordem diferente agora. :)
Kevin Cruijssen 25/04
4

Wolfram Language (Mathematica) , 23 bytes

#2^#3Log@#>#5^#6Log@#4&

Experimente online!

J42161217
fonte
Isso não termina para a1 = 20, a2 = 20, a3 = 20.
Anush em 25/04
@Anush fixed ...
J42161217 25/04
1
Pena quanto ao estouro, caso contrário, ##>0&@@(##^1&@@@#)&são apenas 19 bytes e ainda mais incompreensivelmente semelhantes ao Mathematica do que o código acima. (formato de entrada {{a,b,c},{d,e,f}})
Greg Martin
3

J , 11 9 bytes

>&(^.@^/)

Experimente online!

Argumentos dados como listas.

  • > a esquerda é maior?
  • &(...) mas primeiro, transforme cada argumento assim:
  • ^.@^/reduza-o da direita para a esquerda com exponência. Mas como a exponenciação comum limitará o erro, mesmo para números estendidos, pegamos os logs de ambos os lados
Jonah
fonte
3

Limpo , 44 bytes

import StdEnv
$a b c d e f=b^c/e^f>ln d/ln a

Experimente online!

Usa uma adaptação da fórmula de Arnauld.

Furioso
fonte
1
Eu acredito que isso falha 2^3^12 == 8^3^11.
Ørjan Johansen 26/04
@ ØrjanJohansen Fixed.
Οurous 26/04
3

Python 3 , 68 bytes

lambda a,b,c,d,e,f:log(a,2)*(b**c)>log(d,2)*(e**f)
from math import*

Experimente online!

Resposta da porta do @Arnualds, mas com a base do log alterada.

Artemis apoia Monica
fonte
^é chamado **em Python. E com isso alterado, você não poderá executar todos os casos de teste do OP.
Ørjan Johansen 26/04
Agora deve estar tudo corrigido, 66 bytes.
Artemis apoia Monica em
Eu acredito que isso falha 2^3^12 == 8^3^11.
Ørjan Johansen 26/04
@ ØrjanJohansen deve ser corrigido
Artemis suporta Monica
Parece que sim. Além da alteração da base logarítmica da correção, isso se parece com o método de Arnauld.
Ørjan Johansen
2

05AB1E , 13 bytes

Usa o método da resposta JS de Arnauld

2F.²IIm*ˆ}¯`›

Experimente online!

Emigna
fonte
Isso não termina para a1 = 20, a2 = 20, a3 = 20.
Anush em 25/04
1
@ Anush: Parece terminar em menos de um segundo para mim.
Emigna 25/04
você deve definir todas as variáveis ​​como 20. Consulte tio.run/##yy9OTMpM/f9f79Du3GK9Q6tzHzXs@v8/2shAB4xiuRBMAA
Anush
@ Anush: Ah, você quis dizer b1=b2=b3=20, sim, isso não termina.
Emigna 25/04
1
@ Anush: Está consertado agora. Obrigado por apontar o meu erro :)
Emigna
2

Excel, 28 bytes

=B1^C1*LOG(A1)>E1^F1*LOG(D1)

Implementação em Excel da mesma fórmula já usada.

Wernisch
fonte
Meu entendimento é que o Excel possui 15 dígitos de precisão; portanto, pode haver casos em que o arredondamento resulta no retorno da resposta errada.
Acumulação em 25/04
2

JavaScript, 51 bytes

f=(a,b,c,h,i,j)=>(l=Math.log)(a)*b**c-l(h)*i**j>1e-8

Surpreendentemente, os casos de teste não mostram nenhum erro de ponto flutuante. Não sei se é desse tamanho.

Isso apenas compara o logaritmo dos números.

A tolerância à igualdade é igual a 1e-8.

Naruyoko
fonte
Welcome to PPCG! Alas this does fail with my 2^3^12 == 8^3^11 test case. In fact your answer is very similar to the original answer by Arnauld (sadly deleted rather than fixed) that inspired most of those which failed it.
Ørjan Johansen
@Ørjan Johansen Moved l(h) to the right, and maybe it works now? Edit: Wait, it doesn't.
Naruyoko
Added equality tolerance 0.01.
Naruyoko
Fiz uma pesquisa rápida e a tolerância deve funcionar, mas isso é um pouco alto demais. O mais alto que você precisa excluir é (5.820766091346741e-11,(8.0,3.0,11,2.0,3.0,12))(meu caso de teste) e o mais baixo que você precisa incluir é (9.486076692724055e-4,(17.0,19.0,1,3.0,7.0,2))( 3^7^2 > 17^19^1.) Portanto, algo como 1e-8deve estar em segurança no meio e com o mesmo comprimento de bytes.
Ørjan Johansen 29/04
@ Ørjan Johansen Ok, obrigado!
Naruyoko 29/04
1

bc -l, 47 bytes

l(read())*read()^read()>l(read())*read()^read()

com a entrada lida STDIN, um número inteiro por linha.

bcé bem rápido; ele lida com a = b = c = d = e = f = 1.000.000 em pouco mais de um segundo no meu laptop.


fonte
Eu amo uma resposta bc! Só preciso de um no bash agora :)
Anush
1

C++ (gcc), 86 bytes

Thanks to @ØrjanJohansen for pointing out a flaw in this and @Ourous for giving a fix.

#import<cmath>
int a(int i[]){return pow(i[1],i[2])/pow(i[4],i[5])>log(i[3])/log(*i);}

Try it online!

Takes input as a 6-integer array. Returns 1 if abc>def, 0 otherwise.

Neil A.
fonte
The formula after taking log twice should be i[2]*log(i[1])+log(log(*i)). E.g. the current one will fail for 2^2^20 > 4^2^18.
Ørjan Johansen
@ØrjanJohansen: good catch! I guess I have to use the pow method then.
Neil A.
The alternate one has the 2^3^12 == 8^3^11 problem I've pointed out for others.
Ørjan Johansen
@ØrjanJohansen: well, I guess I'm using your fixed formula then.
Neil A.
Oh, I'm afraid that formula is only mathematically correct. It still has a floating point error problem, just with a different case, 2^3^20 == 8^3^19. In fact on average the power method fails for fewer, probably because it tends to multiply by powers of two exactly. Others have managed to make it work by just tweaking it slightly.
Ørjan Johansen
1

Jelly, 8 bytes

l⁵×*/}>/

Try it online!

Based on Arnauld’s JS answer. Expects as input [a1, b1] as left argument and [[a2, b2], [a3, b3]] as right argument.

Now changed to use log to the base 10 which as far as correctly handles all the possible inputs in the range specified. Thanks to Ørjan Johansen for finding the original problem!

Nick Kennedy
fonte
1
I believe this fails for 2^3^12 == 8^3^11.
Ørjan Johansen
Seu Python TIO é incorrecto .. Você tem 8*, em vez de 8**. @ ØrjanJohansen é realmente correto que 2**(3**12) > 8**(3**11)é falsey, uma vez que são iguais.
Kevin Cruijssen 26/04
@KevinCruijssen oops. Sim, eles são realmente iguais. A razão pela qual os dois originais são marcados como diferentes está relacionada ao erro de ponto flutuante.
Nick Kennedy
1

TI-BASIC, 27 31 bytes

ln(Ans(1))Ans(2)^Ans(3)>Ans(5)^Ans(6)(ln(Ans(4

Entrada é uma lista de comprimento 6no Ans.
Saída true se o primeiro número grande for maior que o segundo número grande. Caso contrário, gera false.

Exemplos:

{3,4,5,5,4,3
   {3 4 5 5 4 3}
prgmCDGF16
               1
{20,20,20,20,20,19       ;these two lines go off-screen
{20 20 20 20 20 19}
prgmCDGF16
               1
{3,6,5,5,20,3
  {3 6 5 5 20 3}
prgmCDGF16
               0

Explicação:

ln(Ans(1))Ans(2)^Ans(3)>Ans(5)^Ans(6)(ln(Ans(4   ;full program
                                                 ;elements of input denoted as:
                                                 ; {#1 #2 #3 #4 #5 #6}

ln(Ans(1))Ans(2)^Ans(3)                          ;calculate ln(#1)*(#2^#3)
                        Ans(5)^Ans(6)(ln(Ans(4   ;calculate (#5^#6)*ln(#4)
                       >                         ;is the first result greater than the
                                                 ; second result?
                                                 ; leave answer in "Ans"
                                                 ;implicit print of "Ans"

Nota: TI-BASIC é um idioma tokenizado. Contagem de caracteres não é igual à contagem de bytes.

Tau
fonte
Não estou familiarizado com o TI-BASIC, mas parece que log(x) × y × zsim log(x) × y ^ z. Isso não leva necessariamente à mesma ordem que a desigualdade original.
Nick Kennedy
@NickKennedy Sim, você está certo sobre isso! Vou atualizar a postagem para explicar isso.
Tau
1

APL (NARS), caracteres 36, bytes 72

{>/{(a b c)←⍵⋄a=1:¯1⋄(⍟⍟a)+c×⍟b}¨⍺⍵}

Aqui abaixo da função z em (abc) z (xyt) retornaria 1 se a ^ (b ^ c)> x ^ (y ^ t) retornasse 0; teste

  z←{>/{(a b c)←⍵⋄a=1:¯1⋄(⍟⍟a)+c×⍟b}¨⍺⍵}
  3 4 5 z 5 4 3
1
  1 2 3 z 3 2 1
0
  3 6 5 z 5 20 3
0
  20 20 20 z 20 20 19
1
  20 20 20 z 20 20 20
0
  2 2 20 z 2 20 2
1
  2 3 12 z 8 3 11
0
  1 20 20 z 1 1 1
0
  1 1 1 z 1 20 20
0
  1 4 5 z 2 1 1
0

{(abc) ← =a = 1: ¯1⋄ ()a) + c × ⍟b} é a função p (a, b, c) = log (log (a)) + c * log (b ) = log (log (a ^ b ^ c)) e se aa = a ^ (b ^ c) com a, b, c> 0 e a> 1 bb = x ^ (y ^ t) com x, y, t> 0 ex> 1 que

aa>bb <=> log(log(a^b^c))>log(log(x^y^t))  <=>  p(a,b,c)>p(x,y,t)

Há um problema com a função p: Quando a é 1, o log de log 1 não existe, então eu escolhi representá-lo com o número -1; quando a = 2, então log log a é um número negativo, mas> -1.

PS. Visto a função em seu conjunto maior, no qual é definido

p(a,b,c)=log(log(a))+c*log(b)

o intervalo de exibição para a, b, c em 1..20 é muito pequeno ... Se alguém observar quando ele ultrapassa a base de log 10, o intervalo para a, b, c pode ser de 1..10000000 ou maior para 64 bits tipo de flutuador.

RosLuP
fonte