第二单元习题
设计函数分别求两个一元多项式的乘积与和。
输入格式:
输入分2行,每行分别先给出多项式非零项的个数,再以指数递降方式输入一个多项式非零项系数和指数(绝对值均为不超过1000的整数)。数字间以空格分隔。
输出格式:
输出分2行,分别以指数递降方式输出乘积多项式以及和多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。零多项式应输出0 0。
情况1,2是常规输入。
加法运算考虑到可能有同指数的系数合并后为0则不输出的情况。
乘法运算是将P1的Num个数分别乘以P2的每个项,然后将这NUM个front指针依次推入一个vector中储存,再进行加法计算合并多项式即可。
注意情况3,结果中有零多项式则输出 0 0。在write()中判断好。
情况4,输入有零多项式,则乘法结果必为零多项式。加法结果为另一个多项式本身。
#include <stdio.h>
#include <iostream>
#include <algorithm>
#include <vector>
typedef struct Node* Polynomial;
struct Node
{
int coef;
int expon;
Polynomial Next;
};
int compare(int a, int b)
{
if (a > b) return 1;
if (a == b) return 0;
if (a < b) return -1;
}
void Write(Polynomial P)
{
if (!P) std::cout << "0 0";
else {
while (P)
{
std::cout << P->coef << " " << P->expon;
if (P->Next != 0) std::cout << " ";
P = P->Next;
}
}
}
void Attach(int coef, int expon, Polynomial *prear)
{
Polynomial P;
P =