Bu sorunun tamsayı / polinom karelemesine eşdeğer olduğu görülüyor:
1. Polinom çoğalmasının tamsayı çoğalmasına eşdeğer olduğu bilinmektedir .
2. Açıkçası, sorunu zaten polinom / tamsayı karelemesine düşürdünüz; bu nedenle bu problem en fazla kareleme kadar zordur.
Şimdi bu soruna tam sayı karesini azaltacağım:
Bir algoritmanız olduğunu varsayalım:
F(a⃗ )→P2(x),where P(x)=∑ai∈a⃗ xai
Bu algoritma aslında sorunuzda talep ettiğiniz algoritmadır. Bunu yapmak için sihirli algoritması olsaydı Böylece, bir fonksiyon, yapabilir tamsayı kare olacaktır y ( : pOH evet, aşkın mathjax do ):SQUARE(y)y
1.:2.:3.:4.:5.:6.:7.:8.:9.:10.:11.:12.:13.:Algorithm 1 Squaringprocedure SQUARE(y):a⃗ ←()i←0while y≠0 doif y & 1 thena⃗ ←a⃗ iend ifi←i+1y←y≫1end whileP2(x)←F(a⃗ )return P2(2)end procedure▹ a⃗ starts as empty polynomial sequence▹ break y down into a polynomial of base 2▹ if lsb of y is set▹ append i to a⃗ (appending xi)▹ shift y right by one▹ obtain the squared polynomial via F(a⃗ )▹ simply sum up the polynomial
Python ( kod takımı ile test ):
#/cs//q/11418/2755
def F(a):
n = len(a)
for i in range(n):
assert a[i] >= 0
# (r) => coefficient
# coefficient \cdot x^{r}
S = {}
for ai in a:
for aj in a:
r = ai + aj
if r not in S:
S[r] = 0
S[r] += 1
return list(S.items())
def SQUARE(x):
x = int(x)
a = []
i = 0
while x != 0:
if x & 1 == 1:
a += [i]
x >>= 1
i += 1
print 'a:',a
P2 = F(a)
print 'P^2:',P2
s = 0
for e,c in P2:
s += (1 << e)*c
return s
3. Böylece kare alma en fazla bu problem kadar zordur.
4. Bu nedenle, tamsayı kare alma bu soruna eşdeğerdir. (( 2 , 3 , 1 ) nedeniyle her biri birbirleri kadar serttir )
O(nlogn)O(nlognloglogn)O(nlogn2O(log∗n))Ω(nlogn)
O(nlogn)
5. Şimdi, probleminiz tam olarak çarpma değil, kareleniyor. Peki kareleme daha kolay mı? Açık bir sorundur (şimdilik hayır) : kareleme, çarpma işleminden daha hızlı bir algoritmaya sahip olduğu bilinmemektedir. Sorununuz için çarpma yönteminden daha iyi bir algoritma bulabiliyorsanız; o zaman bu muhtemelen bir atılım olacaktır.
O(nlogn)O(nlogn)O(nlogn)O(nlogn) ya da en iyi çarpma algoritması sadece bu karmaşıklığa yaklaşır.