Dati due polinomi f,g
di grado arbitrario sugli interi, il tuo programma / funzione dovrebbe valutare il primo polinomio nel secondo polinomio. f(g(x))
(aka la composizione (fog)(x)
dei due polinomi)
Dettagli
Sono ammessi i builtin. Puoi assumere qualsiasi formattazione ragionevole come input / output, ma il formato di input e output dovrebbe corrispondere. Ad esempio, formattazione come stringa
x^2+3x+5
o come elenco di coefficienti:
[1,3,5] or alternatively [5,3,1]
Inoltre, si può presumere che i polinomi di input siano completamente espansi e che anche gli output siano completamente espansi.
Esempi
A(x) = x^2 + 3x + 5, B(y) = y+1
A(B(y)) = (y+1)^2 + 3(y+1) + 5 = y^2 + 5y + 9
A(x) = x^6 + x^2 + 1, B(y) = y^2 - y
A(B(y))= y^12 - 6y^11 + 15y^10 - 20y^9 + 15y^8 - 6y^7 + y^6 + y^4 - 2 y^3 + y^2 + 1
A(x) = 24x^3 - 144x^2 + 288x - 192, B(y) = y + 2
A(B(y)) = 24y^3
A(x) = 3x^4 - 36x^3 + 138x^2 - 180x + 27, B(y) = 2y + 3
A(B(y)) = 48y^4 - 96y^2
(.)
è una risposta in Haskell. Probabilmente intendi una rappresentazione dell'elenco dei coefficienti.