多项式加法对我来说真的有难度,输出既有整数也有浮点数,并且最后一个数字后面不可以有空格。
还有非常容易忽略的一点是两行an数字之和为0的时候那一项是不会输出的。
一开始思路非常繁琐,想用结构体存放整数和浮点数,后来放弃。
在CSDN上寻找了很多思路,发现最简单的还是用下标存储N的值,再用对应的数组值存储an。
借鉴了一波代码之后终于敲出来了。
等过一个月还要回顾这一题。
#include<stdio.h>
int main()
{
float a[1001];
float s;
int i,j,k;
for(i=0;i<1001;i++)
{
a[i]=0.0;
}
scanf("%d",&k);
for(j=0;j<k;j++)
{
scanf("%d%f",&i,&s);
a[i]=a[i]+s;
}
scanf("%d",&k);
for(j=0;j<k;j++)
{
scanf("%d%f",&i,&s);
a[i]=a[i]+s;
}
k=0;
for(i=0;i<1001;i++)
{
if(a[i]!=0.0)
k++;
}
printf("%d",k);
if(k!=0)
printf(" ");//若k!=0,输出k后加一个空格
for(i=1000;i>=0;i--)
{
if(a[i]!=0.0)
{
printf("%d %0.1f",i,a[i]);
k--;
if(k!=0)
printf(" ");//保证最后一个数字输出后不加空格
}
}
return 0;
}