Dados dois polinômios f,g
de grau arbitrário sobre os números inteiros, seu programa / função deve avaliar o primeiro polinômio no segundo polinômio. f(g(x))
(aka a composição (fog)(x)
dos dois polinômios)
Detalhes
Builtins são permitidos. Você pode assumir qualquer formatação razoável como entrada / saída, mas o formato de entrada e saída deve corresponder. Por exemplo, formatação como uma string
x^2+3x+5
ou como lista de coeficientes:
[1,3,5] or alternatively [5,3,1]
Além disso, os polinômios de entrada podem ser assumidos como totalmente expandidos e as saídas também devem ser totalmente expandidas.
Exemplos
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
(.)
é uma resposta em Haskell. Você provavelmente quer dizer alguma representação da lista de coeficientes.