Sembrerebbe che questo problema sia equivalente alla quadratura intera / polinomiale:
1. È noto che la moltiplicazione polinomiale equivale alla moltiplicazione intera .
2. Ovviamente, hai già ridotto il problema alla quadratura polinomiale / intera; quindi questo problema è tanto difficile quanto la quadratura.
Ora ridurrò la quadratura dei numeri interi a questo problema:
Supponiamo di avere un algoritmo:
F(a⃗ )→P2(x),where P(x)=∑ai∈a⃗ xai
Questo algoritmo è essenzialmente l'algoritmo richiesto nella domanda. Quindi, se avessi un algoritmo magico in grado di farlo, posso fare una funzione, chequadreràl'intero y (oh sì, adoro mathjax: P):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 ( test con codepad ):
#/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. Pertanto, la quadratura è difficile al massimo quanto questo problema.
4. Pertanto, la quadratura dei numeri interi è equivalente a questo problema. (sono entrambi al massimo difficili l'uno dall'altro, a causa di ( 2 , 3 , 1 ))
Ora non è noto se la moltiplicazione intera / polinomiale ammetta limiti migliori di ; infatti i migliori algoritmi di moltiplicazione attualmente utilizzano tutti FFT e hanno runtime come O ( n log n log log n ) ( algoritmo di Schönhage-Strassen ) eO(nlogn)O(nlognloglogn)O(nlogn2O(log∗n))Ω(nlogn)
O(nlogn)
5. Ora, il tuo problema non è esattamente la moltiplicazione, ma la quadratura. Quindi la quadratura è più facile? Bene, è un problema aperto (no per ora) : la quadratura non è nota per avere un algoritmo più veloce della moltiplicazione. Se riuscissi a trovare un algoritmo migliore per il tuo problema rispetto all'utilizzo della moltiplicazione; allora questo sarebbe probabilmente un passo avanti.
O(nlogn)O(nlogn)O(nlogn)O(nlogn) in entrambi i casi, poiché il miglior algoritmo di moltiplicazione si avvicina solo a quella complessità.