Nous aimerions factoriser un semi-premier . Le but de ce défi est de trouver deux petits entiers u et v tels que u v N peut être trivialement factorise avec la méthode de Fermat, permettant ainsi de déduire facilement les facteurs de N .
La tâche
Étant donné un semi-premier et un entier positif k , nous définissons x et y comme:
y=x2-kN
Étape # 1 - Trouvez
Vous devez d'abord trouver la plus petite valeur possible de telle que y soit un nombre carré ( aka carré parfait).
Cela permet de factoriser avec une seule itération de la méthode de factorisation de Fermat . Plus concrètement, cela conduit immédiatement à:
(Mise à jour: cette séquence est maintenant publiée sous A316780 )
Étape # 2 - Factoriser
Il faut ensuite trouver les deux entiers positifs et v tels que:
c u = x + √
où et d sont les facteurs premiers de N .
Sommaire
Votre tâche consiste à écrire un programme ou une fonction qui prend comme entrée et imprime ou affiche u et v dans n'importe quel ordre et dans n'importe quel format raisonnable.
Exemple
Considérons
Étape 1
La plus petite valeur possible de est 40 , ce qui donne:
y=28232-40×199163=7969329-7966520=2809=532kN=(2823+53)
Étape 2
La factorisation correcte de est k = 4 × 10 , car:
k N = ( 719 × 4 ) ×
Donc, la bonne réponse serait soit
Règles
- L'entrée est garantie comme un semi-premier.
- Il s'agit de code-golf, donc la réponse la plus courte en octets l'emporte.
- Les failles standard sont interdites.
Cas de test
N | k | Output
-----------+------+------------
143 | 1 | [ 1, 1 ]
2519 | 19 | [ 1, 19 ]
199163 | 40 | [ 4, 10 ]
660713 | 1 | [ 1, 1 ]
4690243 | 45 | [ 9, 5 ]
11755703 | 80 | [ 40, 2 ]
35021027 | 287 | [ 7, 41 ]
75450611 | 429 | [ 143, 3 ]
806373439 | 176 | [ 8, 22 ]
1355814601 | 561 | [ 17, 33 ]
3626291857 | 77 | [ 7, 11 ]
6149223463 | 255 | [ 17, 15 ]
6330897721 | 3256 | [ 74, 44 ]
Exemple d'implémentation
Dans l'extrait ci-dessous, la fonction est une implémentation non gérée qui prend N
N
sera en fait un semi-premier?