Chcielibyśmy czynniki pierwsze Liczba Półpierwsza . Celem wyzwania jest znajdują się dwa małe liczby całkowite u i v , tak że u v N można trywialny factorized metodą Fermata, co pozwala na łatwe odliczać czynniki N .
Zadanie
Biorąc pod uwagę Liczba Półpierwsza i dodatnią liczbą całkowitą k określamy X i Y jako:
y=x2-kN
Krok # 1 - Znajdź
Najpierw musisz znaleźć najmniejszą możliwą wartość tak że y jest liczbą kwadratową ( czyli kwadrat idealny).
Pozwala to na czynniki z pojedynczej iteracji Algorytm Fermata . Mówiąc konkretniej, prowadzi to natychmiast do:
(Aktualizacja: ta sekwencja jest teraz opublikowana jako A316780 )
Krok # 2 - Faktoryzuj
Następnie musisz znaleźć dwie dodatnie liczby całkowite i v takie, że:
c u = x + √
gdzie i d są głównymi czynnikami N .
streszczenie
Twoim zadaniem jest napisanie programu lub funkcji, która przyjmuje jako dane wejściowe i drukuje lub wyjściowe u i v w dowolnej kolejności i dowolnym rozsądnym formacie.
Przykład
Rozważmy
Krok 1
Najmniejsza możliwa wartość wynosi 40 , co daje:
r=2.8232-40x199163=7969329-7966520=2809=532KN=(2823+53)x(2823-53)kN=2876x2770
Krok 2
Prawidłowa faktoryzacja wynosi k = 4 × 10 , ponieważ:
Zasady
- Dane wejściowe są gwarantowane jako półpierwsze.
- To jest golf golfowy, więc wygrywa najkrótsza odpowiedź w bajtach.
- Standardowe luki są zabronione.
Przypadki testowe
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 ]
Przykładowa implementacja
źródło
N
będą w rzeczywistości półpierwszymi?Odpowiedzi:
Mathematica,
8179 bajtówDzięki Martin Ender za oszczędność 2 bajtów!
Czysta funkcja przyjmująca półpierwsze jako dane wejściowe i zwracająca uporządkowaną parę dodatnich liczb całkowitych. Te
For
narzędzia pętla dokładna procedura opisana w pytaniu (przy użyciu#
do wprowadzania w miejscun
), zx
, jak tu zdefiniowana, mimo że przechowywaniej = k*n
zamiastk
siebie iz=Sqrt[y]
zamiasty
siebie. Obliczamy równieżp={x+z,x-z}
wewnątrzFor
pętli, co kończy się oszczędzaniem jednego bajtu (jak przy siódmej próbie). Następnie dwoma pożądanymi czynnikami są(x+z)/GCD[#,x+z]
i(x-z)/GCD[#,x-z]
, które zwięzłe wyrażeniep/#~GCD~p
oblicza bezpośrednio jako parę uporządkowaną.Ciekawostki: chcemy zapętlać, aż
z
będzie liczbą całkowitą; ale ponieważ zamierzamy użyćCeiling
już w kodzie, oszczędza dwa bajty,!IntegerQ@z
aby zdefiniowaćc=Ceiling
(co kosztuje cztery bajty, jak wiedzą golfiści Mathematica), a następnie przetestować, czyc@z>z
. Musimyz
coś zainicjować i że coś nie powinno być liczbą całkowitą, aby pętla mogła się rozpocząć; na szczęścieE
jest to zwięzły wybór.źródło
JavaScript (ES7),
8681 bajtówEdycja: Zapisano 4 bajty dzięki @Arnauld.
źródło
Python 2,
12712111711110710410199 bajtów-1 bajt dzięki Neilowi i -3 bajty dzięki ovs
Wypróbuj online!
Ciekawostki:
p
jest inicjalizowany, aby.5
warunek pętli był spełniony przy pierwszej iteracji. Należy pamiętać, że jest on krótszy do sklepup
(jakox
+sqrt(y)
), niż jest do przechowywania każdegox
iy
oddzielnie.źródło
x*x
zamiastx**2
?Aksjomat,
131115 bajtówFunkcja, która rozwiązałaby pytanie, to r (n) powyżej. golf i test
źródło