
题目大意:给出格式相同的两行,第一行的第一个整数K表示多项式A的非零项的个数,后面的每两个数表示一项,分别是该项的指数和系数;第二行则表示多项式B的相关项的个数。
求A+B,即多项式求和。输出格式同输入格式,第一个K仍是A+B的非零项的个数。
#include<bits/stdc++.h>
using namespace std;
#define ll long long
double epi=1e-6;
const int maxn=1e3+5;
double q[maxn];
double w[maxn];
double ans[maxn];
int main()
{
int a,b;
scanf("%d",&a);
for(int i=1; i<=a; i++)
{
int x;
double y;
scanf("%d",&x);
scanf("%lf",&y);
q[x]=y;
}
scanf("%d",&b);
for(int i=1; i<=b; i++)
{
int x;
double y;
scanf("%d",&x);
scanf("%lf",&y);
w[x]=y;
}
int cnt=0;
for(int i=maxn; i>=0; i--)
{
ans[i]=w[i]+q[i];
}
for(int i=maxn; i>=0; i--)
{
if(ans[i])
{
cnt++;
}
}
printf("%d",cnt);
for(int i=maxn; i>=0; i--)
{
if(ans[i])
{
cnt--;
printf(" %d %.1lf",i,ans[i]);
}
}
return 0;
}
这篇博客主要介绍了如何实现两个多项式的加法操作。通过读取每个多项式的非零项,将它们相加并存储结果。最后输出新的多项式,其非零项按指数递减顺序排列。
796

被折叠的 条评论
为什么被折叠?



