Dado un número entero positivo n y un número a , el n -ésimo tetración de una se define como un ^ ( un ^ ( un ^ (... ^ una ))), donde ^ denota exponenciación (o potencia) y la expresión contiene el número de una exactamente n veces.
En otras palabras, la tetración es exponenciación iterativa asociativa derecha. Para n = 4 y a = 1.6 la tetración es 1.6 ^ (1.6 ^ (1.6 ^ 1.6)) ≈ 3.5743.
La función inversa de la tetración con respecto a n es el superlogaritmo . En el ejemplo anterior, 4 es el superlogaritmo de 3.5743 con "superbase" 1.6.
El reto
Dado un número entero positivo n , encuentre x tal que n sea el superlogaritmo de sí mismo en la superbase x . Es decir, encuentre x tal que x ^ ( x ^ ( x ^ (... ^ x ))) (con x apareciendo n veces) es igual a n .
Reglas
Programa o función permitida.
Los formatos de entrada y salida son flexibles como de costumbre.
El algoritmo debería funcionar teóricamente para todos los enteros positivos. En la práctica, la entrada puede limitarse a un valor máximo debido a restricciones de memoria, tiempo o tipo de datos. Sin embargo, el código debe funcionar para entradas hasta al 100
menos en menos de un minuto.
El algoritmo teóricamente debería dar el resultado con 0.001
precisión. En la práctica, la precisión de salida puede ser peor debido a los errores acumulados en los cálculos numéricos. Sin embargo, la salida debe ser precisa 0.001
para los casos de prueba indicados.
El código más corto gana.
Casos de prueba
1 -> 1
3 -> 1.635078
6 -> 1.568644
10 -> 1.508498
25 -> 1.458582
50 -> 1.448504
100 -> 1.445673
Implementación de referencia
Aquí hay una implementación de referencia en Matlab / Octave (pruébelo en Ideone ).
N = 10; % input
t = .0001:.0001:2; % range of possible values: [.0001 .0002 ... 2]
r = t;
for k = 2:N
r = t.^r; % repeated exponentiation, element-wise
end
[~, ind] = min(abs(r-N)); % index of entry of r that is closest to N
result = t(ind);
disp(result)
Por N = 10
esto da result = 1.5085
.
El siguiente código es una verificación de la precisión de salida, usando aritmética de precisión variable:
N = 10;
x = 1.5085; % result to be tested for that N. Add or subtract 1e-3 to see that
% the obtained y is farther from N
s = num2str(x); % string representation
se = s;
for n = 2:N;
se = [s '^(' se ')']; % build string that evaluates to iterated exponentiation
end
y = vpa(se, 1000) % evaluate with variable-precision arithmetic
Esto da:
- Para
x = 1.5085
:y = 10.00173...
- Para
x = 1.5085 + .001
:y = 10.9075
- Por
x = 1.5085 - .001
eso day = 9.23248
.
Por lo tanto, 1.5085
es una solución válida con .001
precisión.
x
Converge a medida que sen
acerca al infinito?Respuestas:
Dyalog APL ,
3325 bytesNecesidades, lo
⎕IO←0
cual es predeterminado en muchos sistemas.Calcula teóricamente para todos los enteros, pero prácticamente limitado a uno muy pequeño.
TryAPL en línea!
fuente
Haskell,
555452 bytesUso:
¡Gracias a @nimi por 1 byte!
Gracias a @xnor por 2!
fuente
[ ]!!0
en lugar dehead[ ]
guardar un bytes n=[x|x<-[2,1.9999..],n>iterate(x**)1!!n]!!0
sería más corto si pudiera hacer que Haskell aceptara sus tipos.Javascript, ES6: 77 bytes / ES7:
5753 bytesES6
ES7
Utilizando
**
según lo sugerido por DanTheMan:Ejemplo
fuente
**
lugar deMath.pow
.Mathematica,
4033 bytes¡Gracias a murphy por un ahorro de casi el 20%!
Nest[x^#&,1,n]
produce la enésima tetración de x. Por lo tanto,Nest[x^#&,1,#]<#
prueba si la (entrada) th tentación de x es menor que (entrada). Simplemente comenzamos en x = 1 y agregamos 0.001 repetidamente hasta que la tentación es demasiado grande, luego emitimos el último valor de x (por lo que se garantiza que la respuesta será mayor que el valor exacto, pero dentro de 0.001).Como estoy aprendiendo lentamente:
//.x_:>y/;z
o//.x_/;z:>y
significa "buscar cualquier cosa que coincida con la plantilla x, pero solo las cosas para las cuales la prueba z devuelve verdadero; y luego operar en x por la regla y; repetidamente hasta que nada cambie". Aquí la plantillax_
es simplemente "cualquier número que veo", aunque en otros contextos podría estar más restringido.Cuando la entrada es al menos 45, la tetración aumenta tan rápidamente que el último paso provoca un error de desbordamiento; pero el valor de x todavía se actualiza y se muestra correctamente. Disminuir el tamaño del paso de 0.001 a 0.0001 soluciona este problema para entradas de hasta 112, y brinda una respuesta más precisa al inicio (y aún se ejecuta rápidamente, en aproximadamente un cuarto de segundo). Pero ese es un byte extra, ¡así que olvídalo!
Versión original:
fuente
1//.x_:>x+.001/;Nest[x^#&,1,#]<#&
//.
sin ayuda :)J,
393128 bytesBasado en la implementación de referencia. Solo tiene una precisión de tres decimales.
Se guardaron 8 bytes usando el método de la solución de @ Adám .
Uso
Comandos adicionales utilizados para formatear múltiples entradas / salidas.
Explicación
fuente
Python, 184 bytes
Salida de prueba (omitiendo las declaraciones de impresión reales):
fuente
s(1000000)
bastante rápidoRaqueta 187 bytes
Pruebas:
Salida:
Versión detallada:
fuente
Perl 6 , 42 bytes
(Traducción de ejemplo de código Matlab)
Prueba:
fuente
PHP, 103 bytes
fuente
Axioma 587 bytes
menos golf + números
fuente
Lisp común, 207 bytes
Usar
reduce
con:from-end t
evita la necesidad de hacer una lambda intermedia de "exponenciación inversa" (básicamente(lambda (x y) (expt y x))
, ahorrando 14 bytes (12, si elimina espacios extraíbles).Todavía tenemos que manejar el desbordamiento de flotación, pero un
ignore-errors
formulario regresanil
si ocurrió un error, por lo que podemos usaror
para proporcionar un valor predeterminado.fuente