Учитывая два многочлена f,g
произвольной степени по целым числам, ваша программа / функция должна вычислять первый многочлен во втором многочлене. f(g(x))
(он же композиция (fog)(x)
двух полиномов)
Детали
Встроенные разрешены. Вы можете принять любое разумное форматирование в качестве ввода / вывода, но формат ввода и вывода должен совпадать. Например, форматирование в виде строки
x^2+3x+5
или как список коэффициентов:
[1,3,5] or alternatively [5,3,1]
Кроме того, можно предположить, что входные полиномы полностью расширены, а выходные данные также должны быть полностью расширены.
Примеры
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
(.)
является ответом в Haskell. Вы, вероятно, имеете в виду некоторое представление списка коэффициентов.