题目:
问题 D: DS线性表—多项式相加
时间限制: 1 Sec 内存限制: 128 MB
提交: 353 解决: 175
[提交][状态][讨论版]
题目描述
对于一元多项式 p(x)=p0+p1x+p2x2+ … +pnxn ,每个项都有系数和指数两部分,例如p2x2的系数为p2,指数为2。
编程实现两个多项式的相加。
例如5+x+2x2+3x3,-5-x+6x2+4x4,两者相加结果:8x2+3x3+4x4
其中系数5和-5都是x的0次方的系数,相加后为0,所以不显示。x的1次方同理不显示。
要求用单链表实现。
输入
第1行:输入t表示有t组测试数据
第2行:输入n表示有第1组的第1个多项式包含n个项
第3行:输入第一项的系数和指数,以此类推输入n行
接着输入m表示第1组的第2个多项式包含m项
同理输入第2个多项式的m个项的系数和指数
参考上面输入第2组数据,以此类推输入t组
假设所有数据都是整数
输出
对于每1组数据,先用两行输出两个原来的多项式,再用一行输出运算结果,不必考虑结果全为0的情况
输出格式参考样本数据,格式要求包括:
1.如果指数或系数是负数,用小括号括起来。
2.如果系数为0,则该项不用输出。
3.如果指数不为0,则用符号^表示,例如x的3次方,表示为x^3。
4.多项式的每个项之间用符号+连接,每个+两边加1个空格隔开。
样例输入
2
4
5 0
1 1
2 2
3 3
4
-5 0
-1 1
6 2
4 4
3
-3 0
-5 1
2 2
4
9 -1
2 0
3 1
-2 2
样例输出
5 + 1x^1 + 2x^2 + 3x^3
(-5) + (-1)x^1 + 6x^2 + 4x^4
8x^2 + 3x^3 + 4x^4
(-3) + (-5)x^1 + 2x^2
9x^(-1) + 2 + 3x^1 + (-2)x^2
9x^(-1) + (-1) + (-2)x^1
代码块:
#include <iostream>
using namespace std;
class SqList
{
public:
int *elem;
int listsize;
int length;
SqList();
~SqList();
};
SqList::SqList()
{
elem = new int[100];
listsize = 100;
length = 0;
}
SqList::~SqList()
{
elem = NULL;
listsize = 0;
length = 0;
}
int main(void)
{
int i, j, t;
cin>>t;
while(t--)
{
SqList L11, L12;
SqList L21, L22;
SqList L31, L32;
int n1, n2;
cin>>n1;
for(i=0; i<n1; i++)
cin>>L11.elem[i]>>L12.elem[i];
for(i=0; i<n1; i++)
{
if(L12.elem[i]<0)
{
if(L11.elem[i]<0)
cout<<'('<<L11.elem[i]<<')'<<'x'<<'^'<<'('<<L12.elem[i]<<')';
else
cout<<L11.elem[i]<<'x'<<'^'<<'('<<L12.elem[i]<<')';
}
else if(L12.elem[i]>0)
{
if(L11.elem[i]<0)
cout<<'('<<L11.elem[i]<<')'<<'x'<<'^'<<L12.elem[i];
else
cout<<L11.elem[i]<<'x'<<'^'<<L12.elem[i];
}
else
{
if(L11.elem[i]<0)
cout<<'('<<L11.elem[i]<<')';
else
cout<<L11.elem[i];
}
if(i!=n1-1)
cout<<" + ";
}
cout<<endl;
cin>>n2;
for(i=0; i<n2; i++)
cin>>L21.elem[i]>>L22.elem[i];
for(i=0; i<n2; i++)
{
if(L22.elem[i]<0)
{
if(L21.elem[i]<0)
cout<<'('<<L21.elem[i]<<')'<<'x'<<'^'<<'('<<L22.elem[i]<<')';
else
cout<<L21.elem[i]<<'x'<<'^'<<'('<<L22.elem[i]<<')';
}
else if(L22.elem[i]>0)
{
if(L21.elem[i]<0)
cout<<'('<<L21.elem[i]<<')'<<'x'<<'^'<<L22.elem[i];
else
cout<<L21.elem[i]<<'x'<<'^'<<L22.elem[i];
}
else
{
if(L21.elem[i]<0)
cout<<'('<<L21.elem[i]<<')';
else
cout<<L21.elem[i];
}
if(i!=n2-1)
cout<<" + ";
}
cout<<endl;
int k = 0;
int i = 0;
int j = 0;
while(i!=n1 && j!=n2)
{
if(L12.elem[i]<L22.elem[j])
{
L32.elem[k] = L12.elem[i];
L31.elem[k] = L11.elem[i];
k++;
i++;
continue;
}
else if(L12.elem[i]==L22.elem[j])
{
if(L11.elem[i]+L21.elem[j]==0)
{
i++;
j++;
continue;
}
else
{
L32.elem[k] = L12.elem[i];
L31.elem[k] = L11.elem[i]+L21.elem[j];
k++;
i++;
j++;
continue;
}
}
else
{
L32.elem[k] = L22.elem[j];
L31.elem[k] = L21.elem[j];
k++;
j++;
continue;
}
}
while(j!=n2)
{
L32.elem[k] = L22.elem[j];
L31.elem[k] = L21.elem[j];
k++;
j++;
}
while(i!=n1)
{
L32.elem[k] = L12.elem[i];
L31.elem[k] = L11.elem[i];
k++;
i++;
}
for(i=0; i<k; i++)
{
if(L32.elem[i]<0)
{
if(L31.elem[i]<0)
cout<<'('<<L31.elem[i]<<')'<<'x'<<'^'<<'('<<L32.elem[i]<<')';
else
cout<<L31.elem[i]<<'x'<<'^'<<'('<<L32.elem[i]<<')';
}
else if(L32.elem[i]>0)
{
if(L31.elem[i]<0)
cout<<'('<<L31.elem[i]<<')'<<'x'<<'^'<<L32.elem[i];
else
cout<<L31.elem[i]<<'x'<<'^'<<L32.elem[i];
}
else
{
if(L31.elem[i]<0)
cout<<'('<<L31.elem[i]<<')';
else
cout<<L31.elem[i];
}
if(i!=k-1)
cout<<" + ";
}
cout<<endl;
}
}