Fraction continue de la somme numérique des racines carrées

10

introduction

Votre tâche consiste à générer les 1000 premiers termes dans la représentation de fraction continue de la somme numérique de la racine carrée de 2 et de la racine carrée de 3.

En d'autres termes, produisez exactement la liste suivante (mais le format de sortie est flexible)

[2, 6, 1, 5, 7, 2, 4, 4, 1, 11, 68, 17, 1, 19, 5, 6, 1, 5, 3, 2, 1, 2, 3, 21, 1, 2, 1, 2, 2, 9, 8, 1, 1, 1, 1, 6, 2, 1, 4, 1, 1, 2, 3, 7, 1, 4, 1, 7, 1, 1, 4, 22, 1, 1, 3, 1, 2, 1, 1, 1, 7, 2, 7, 2, 1, 3, 14, 1, 4, 1, 1, 1, 15, 1, 91, 3, 1, 1, 1, 8, 6, 1, 1, 1, 1, 3, 1, 2, 58, 1, 8, 1, 5, 2, 5, 2, 1, 1, 7, 2, 3, 3, 22, 5, 3, 3, 1, 9, 1, 2, 2, 1, 7, 5, 2, 3, 10, 2, 3, 3, 4, 94, 211, 3, 2, 173, 2, 1, 2, 1, 14, 4, 1, 11, 6, 1, 4, 1, 1, 62330, 1, 17, 1, 5, 2, 5, 5, 1, 9, 3, 1, 2, 1, 5, 1, 1, 1, 11, 8, 5, 12, 3, 2, 1, 8, 6, 1, 3, 1, 3, 1, 2, 1, 78, 1, 3, 2, 442, 1, 7, 3, 1, 2, 3, 1, 3, 2, 9, 1, 6, 1, 2, 2, 2, 5, 2, 1, 1, 1, 6, 2, 3, 3, 2, 2, 5, 2, 2, 1, 2, 1, 1, 9, 4, 4, 1, 3, 1, 1, 1, 1, 5, 1, 1, 4, 12, 1, 1, 1, 4, 2, 15, 1, 2, 1, 3, 2, 2, 3, 2, 1, 1, 13, 11, 1, 23, 1, 1, 1, 13, 4, 1, 11, 1, 1, 2, 3, 14, 1, 774, 1, 3, 1, 1, 1, 1, 1, 2, 1, 3, 2, 1, 1, 1, 8, 1, 3, 10, 2, 7, 2, 2, 1, 1, 1, 2, 2, 1, 11, 1, 2, 5, 1, 4, 1, 4, 1, 16, 1, 1, 1, 1, 2, 1, 1, 1, 2, 1, 8, 1, 2, 1, 1, 22, 3, 1, 8, 1, 1, 1, 1, 1, 9, 1, 1, 4, 1, 2, 1, 2, 3, 5, 1, 3, 1, 77, 1, 7, 1, 1, 1, 1, 2, 1, 1, 27, 16, 2, 1, 10, 1, 1, 5, 1, 6, 2, 1, 4, 14, 33, 1, 2, 1, 1, 1, 2, 1, 1, 1, 29, 2, 5, 3, 7, 1, 471, 1, 50, 5, 3, 1, 1, 3, 1, 3, 36, 15, 1, 29, 2, 1, 2, 9, 5, 1, 2, 1, 1, 1, 1, 2, 15, 1, 22, 1, 1, 2, 7, 1, 5, 9, 3, 1, 3, 2, 2, 1, 8, 3, 1, 2, 4, 1, 2, 6, 1, 6, 1, 1, 1, 1, 1, 5, 7, 64, 2, 1, 1, 1, 1, 120, 1, 4, 2, 7, 3, 5, 1, 1, 7, 1, 3, 2, 3, 13, 2, 2, 2, 1, 43, 2, 3, 3, 1, 2, 4, 14, 2, 2, 1, 22, 4, 2, 12, 1, 9, 2, 6, 10, 4, 9, 1, 2, 6, 1, 1, 1, 14, 1, 22, 1, 2, 1, 1, 1, 1, 118, 1, 16, 1, 1, 14, 2, 24, 1, 1, 2, 11, 1, 6, 2, 1, 2, 1, 1, 3, 6, 1, 2, 2, 7, 1, 12, 71, 3, 2, 1, 9, 1, 1, 1, 1, 1, 1, 1, 1, 1, 7, 1, 3, 5, 5, 1, 1, 1, 1, 4, 1, 1, 1, 3, 1, 4, 2, 19, 1, 16, 2, 15, 1, 1, 3, 2, 3, 2, 4, 1, 3, 1, 1, 7, 1, 2, 2, 117, 2, 2, 8, 2, 1, 5, 1, 3, 12, 1, 10, 1, 4, 1, 1, 2, 1, 5, 2, 33, 1, 1, 1, 1, 1, 18, 1, 1, 1, 4, 236, 1, 11, 4, 1, 1, 11, 13, 1, 1, 5, 1, 3, 2, 2, 3, 3, 7, 1, 2, 8, 5, 14, 1, 1, 2, 6, 7, 1, 1, 6, 14, 22, 8, 38, 4, 6, 1, 1, 1, 1, 7, 1, 1, 20, 2, 28, 4, 1, 1, 4, 2, 2, 1, 1, 2, 3, 1, 13, 1, 2, 5, 1, 4, 1, 3, 1, 1, 2, 408, 1, 29, 1, 6, 67, 1, 6, 251, 1, 2, 1, 1, 1, 8, 13, 1, 1, 1, 15, 1, 16, 23, 12, 1, 3, 5, 20, 16, 4, 2, 1, 8, 1, 2, 2, 6, 1, 2, 4, 1, 9, 1, 7, 1, 1, 1, 64, 10, 1, 1, 2, 1, 8, 2, 1, 5, 4, 2, 5, 6, 7, 1, 2, 1, 2, 2, 1, 4, 11, 1, 1, 4, 1, 714, 6, 3, 10, 2, 1, 6, 36, 1, 1, 1, 1, 10, 2, 1, 1, 1, 3, 2, 1, 6, 1, 8, 1, 1, 1, 1, 1, 1, 1, 2, 40, 1, 1, 1, 5, 1, 3, 24, 2, 1, 6, 2, 1, 1, 1, 7, 5, 2, 1, 2, 1, 6, 1, 1, 9, 1, 2, 7, 6, 2, 1, 1, 1, 2, 1, 12, 1, 20, 7, 3, 1, 10, 1, 8, 1, 3, 1, 1, 1, 1, 2, 1, 1, 6, 1, 2, 1, 5, 1, 1, 1, 5, 12, 1, 2, 1, 2, 1, 2, 1, 1, 3, 1, 1, 1, 8, 2, 4, 1, 3, 1, 1, 1, 2, 1, 11, 3, 2, 1, 7, 18, 1, 1, 17, 1, 1, 7, 4, 6, 2, 5, 6, 4, 4, 2, 1, 6, 20, 1, 45, 5, 6, 1, 1, 3, 2, 3, 3, 19, 1, 1, 1, 1, 1, 1, 34, 1, 1, 3, 2, 1, 1, 1, 1, 1, 4, 1, 2, 1, 312, 2, 1, 1, 1, 3, 6, 6, 1, 2, 25, 14, 281, 4, 1, 37, 582, 3, 20, 2, 1, 1, 1, 2, 1, 3, 7, 8, 4, 1, 11, 2, 3, 183, 2, 23, 8, 72, 2, 2, 3, 8, 7, 1, 4, 1, 4, 1, 2, 2, 1, 2, 1, 8, 2, 4, 1, 2, 1, 2, 1, 1, 2, 1, 1, 10, 2, 1, 1, 5, 2, 1, 1, 1, 2, 1, 1, 2, 1, 3, 2, 9]

Défi

L'introduction générale suivante à la fraction continue est tirée du défi Simplifier une fraction continue .

Les fractions continues sont des expressions qui décrivent les fractions de manière itérative. Ils peuvent être représentés graphiquement:

fraction continue

Ou ils peuvent être représentés comme une liste de valeurs: [a0, a1, a2, a3, ... an]

Ce défi consiste à découvrir la fraction continue de la somme en chiffres de sqrt(2)et sqrt(3), la somme en chiffres est définie comme suit,

Prenez les chiffres dans la représentation décimale de sqrt(2)et sqrt(3), et obtenez la somme chiffre par chiffre:

    1.  4  1  4  2  1  3  5  6  2  3 ...
+   1.  7  3  2  0  5  0  8  0  7  5 ...
=   2. 11  4  6  2  6  3 13  6  9  8 ...

Ensuite, ne conservez que le dernier chiffre de la somme et recompilez-les à la représentation décimale d'un nombre réel

    1.  4  1  4  2  1  3  5  6  2  3 ...
+   1.  7  3  2  0  5  0  8  0  7  5 ...
=   2. 11  4  6  2  6  3 13  6  9  8 ...
->  2.  1  4  6  2  6  3  3  6  9  8 ...

La somme des chiffres de sqrt(2)et sqrt(3)est donc 2.1462633698..., et lorsqu'elle est exprimée avec une fraction continue, les 1000 premières valeurs (c'est- à- dire à ) obtenues sont celles répertoriées dans la section d'introduction.a0a999

Spécifications

  • Vous pouvez écrire une fonction ou un programme complet. Aucun des deux ne devrait accepter de données. En d'autres termes, la fonction ou le programme doit fonctionner correctement sans aucune entrée. Peu importe ce que fait la fonction ou le programme si une entrée non vide est fournie.

  • Vous devez sortir vers STDOUT. Ce n'est que si votre langue ne prend pas en charge la sortie vers STDOUT que vous devez utiliser l'équivalent le plus proche dans votre langue.

  • Vous n'avez pas besoin de garder STDERR propre, et l'arrêt du programme par erreur est autorisé tant que la sortie requise est effectuée dans STDOUT ou ses équivalents.

  • Vous pouvez fournir une sortie via n'importe quel formulaire standard .

  • C'est le , le plus petit nombre d'octets gagne.

  • Comme d'habitude, les failles par défaut s'appliquent ici.

Weijun Zhou
la source

Réponses:

2

Script Kotlin 1.1 , 304 293 octets

import java.math.BigDecimal as b
import java.math.*
val m=MathContext(1022)
var B=b(2)
var A=b((""+B.sqrt(m)).zip(""+b(3).sqrt(m)).joinToString(""){(a,b)->if(a=='.')".";else ""+(a-'0'+(b-'0'))%10})
val g=b(1).setScale(1022)
repeat(1000){println(B);A=g/(A-B);B=A.setScale(0,RoundingMode.FLOOR)}

Un peu bavard malheureusement: /

Doit être exécuté avec JDK 9, comme cela a sqrtété ajouté BigDecimaldans cette version. Fait intéressant, je n'ai pas pu trouver de site TIO avec les fonctionnalités de Kotlin 1.1 et JDK 9 (Ideone et repl.it exécutent tous les deux Kotlin 1.0, qui ne prend pas en charge la déstructuration dans lambdas, et TIO se plaint de son inexistence sqrt.)

Imprime chaque élément séparé par une nouvelle ligne.

Edit ( -11): déplacé printlnau début du corps de la boucle et ajouté une itération supplémentaire pour éviter de répéter l'appel de méthode. Un calcul supplémentaire est effectué, mais il n'est utilisé pour rien.

Moira
la source
2

Python 2 , 193 ... 179 178 octets

d=10
u=d**2000
v=u*u
def s(n,a=d,i=9):
 while a-i:i,a=a,(a+n/a)/2
 return a
p,q,r,t=s(2*v),s(3*v),1,0
while p:t+=(p+q)%d*r;p/=d;q/=d;r*=d
for i in range(1000):print t/u;t=v/(t%u)

Essayez-le en ligne!

Calculer sqrt(2)et sqrt(3)avec une telle précision avec un code court est un travail difficile en Python et dans d'autres langages.

2000 chiffres sont nécessaires pour s'assurer que l'expansion est correcte (1020 suffit, mais je ne vais pas la modifier car aucune amélioration), et les lignes 4-6 sont la racine carrée entière.

193> 180: La somme modulo au niveau des chiffres est maintenant portée par une boucle au lieu d'une manipulation de tableau

180> 179: Remplacement des 6 occurrences d' 10utilisation dpar le coût de définition avec 5 octets, coupant 1 octet au total

179> 178: Je viens de réaliser qu'il a!=ipeut être remplacé para-i

Shieru Asakoto
la source
1

Gelée , 32 octets

ȷ*`
%¢¢²¤:
2,3×Ñ×ÑƽDS%⁵ḌÇȷСṖ:Ñ

Essayez-le en ligne!


Fondamentalement, utilisez l'arithmétique à virgule fixe. M peut fonctionner mieux ici, mais floor(HUGE_NUMBER × sqrt(2)ne veut pas en quelque sorte évaluer trop grand HUGE_NUMBER. Quoi qu'il en soit, la division en virgule fixe est nettement meilleure.


Explication:

-------
ȷ*`       Calculate the base for fixed-point arithmetic.
ȷ         Number 1000.
 *        Raise to the power of...
  `       self. (so we have 1000 ** 1000 == 1e3000) Let B=1e3000.

-------
%¢¢²¤:    Given f × B, return a number approximately (1/frac(f)) × B.
          Current value: f × B.
%¢        Modulo by B. Current value: frac(f) × B.
  ¢²¤     B² (that is, 1e6000)
     :    integer-divide by. So we get B²/(frac(f)×B) ≃ 1/frac(f) × B.

-------
2,3×Ñ×ÑƽDS%⁵ḌÇȷСṖ:Ñ  Main link.
2,3                    The list [2,3].

    Ñ                  This refers to the next link as a monad, which is the
                       first link (as Jelly links wraparound)
   ×                   Multiply by. So we get [2,3]×1e3000 = [2e3000,3e3000]
     ×Ñ                Again. Current value = [2e6000,3e6000] = [2B²,3B²]

       ƽ              Integer square root.
                       Current value ≃ [sqrt(2B²),sqrt(3B²)]
                                     = [B sqrt(2),B sqrt(3)]

         DS            Decimal digits, and sum together.
           %⁵          Modulo 10.
             Ḍ         Convert back from decimal digits to integer.

                С     Repeatedly apply...
              Ç          the last link...
               ȷ         for 1000 times, collecting the intermediate results.
                  Ṗ    Pop, discard the last result.
                   :Ñ  Integer divide everything by B.
user202729
la source
Malheureusement, ×⁺Ñcela ne fonctionne pas. Alternativement ×Ѳ$.
user202729
A voté. Une explication serait très appréciée.
Weijun Zhou
1
@WeijunZhou Terminé, dites-moi si vous ne comprenez pas quelque chose.
user202729
1

Haskell 207 octets

Je ne pouvais pas trouver un moyen facile de calculer la fraction continue paresseusement, alors j'ai également travaillé avec 2000 chiffres.

import Data.Ratio
r#y|x<-[x|x<-[9,8..],r>(y+x)*x]!!0=x:(100*(r-(y+x)*x))#(10*y+20*x)
c r|z<-floor r=z:c(1/(r-z%1))
main=print.take 1000.c$foldl1((+).(10*))(take 2000$(`mod`10)<$>zipWith(+)(3#0)(2#0))%10^1999
Damien
la source
Quel dommage! Je m'attendais à voir une réponse Haskell qui génère la liste infinie et à l'évaluer paresseusement ...
Weijun Zhou
@WeijunZhou Je vais essayer plus tard quand j'aurai du temps. Au moins sqrt génère une liste infinie. J'ai juste besoin de comprendre comment inverser un nombre décimal écrit en liste infinie. Peut-être que quelqu'un peut aider
Damien