Biorąc pod uwagę dwa wielomiany f,g
o dowolnym stopniu względem liczb całkowitych, twój program / funkcja powinna ocenić pierwszy wielomian w drugim wielomianu. f(g(x))
(aka skład (fog)(x)
dwóch wielomianów)
Detale
Wbudowane są dozwolone. Możesz założyć dowolne rozsądne formatowanie jako wejście / wyjście, ale format wejścia i wyjścia powinien być zgodny. Np. Formatowanie jako ciąg
x^2+3x+5
lub jako lista współczynników:
[1,3,5] or alternatively [5,3,1]
Ponadto można założyć, że wielomiany wejściowe są w pełni rozwinięte, a oczekuje się, że wyjściowe zostaną w pełni rozwinięte.
Przykłady
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
(.)
jest odpowiedzią w języku Haskell. Prawdopodobnie masz na myśli pewną reprezentację listy współczynników.