Цель работы: Разработать программу, выполняющую фрифметические операции с полиномами трех переменных: сложение, вычитание, умножение на константу, умножение двух полиномов. Считается, что полином составлен из мономов от трех переменных со степенью от 0 до 9. Коэффициенты полинома - вещественные числа. Работоспособность программы необходимо проверить с помощью Google Test-ов. Кроме того, необходимо разработать пользовательское консольное приложение.
Особенности реализации:
- В качестве структуры хранения полинома использовать односвязный список мономов с ненулевыми коэффициентами. Список удобнее реализовать с фиктивной головой (зацикленный - по желанию). Элементы списка хранить упорядоченными
- Степень полинома хранить в "свернутом" виде, т. е. степень должна быть представлена как трехзначное число, где число сотен – это степень при переменной “x”, число десятков - степень при переменной “y”, число единиц - степень при переменной “z”.
- Сложение полиномов осуществлять алгоритмом слияния упорядоченных массивов.
- Вычитание полиномов допускается выполнять через сложение с умножением на константу (C = A - B = A + (-1)*B)
- При умножении необходимо следить, чтобы в итоговом полиноме были приведены подобные слагаемые и не хранилось мономов с нулевым коэффициентом.
- Если при умножении полиномов полученные степени переменных больше 9, выводить сообщение об ошибке.
- Считывание полинома у пользователя допускается в любом удобном для вас виде.
- Следует учесть, что пользователь может вводить полином, не упорядочив в нем мономы.