PAT 甲级1002 A+B for Polynomials (25 分)

1002 A+B for Polynomials (25 分)
This time, you are supposed to find A+B where A and B are two polynomials.
Input Specification:
Each input file contains one test case. Each case occupies 2 lines, and each line contains the information of a polynomial:
K N1 aN1 N2 aN2 ... NK aNK
where K is the number of nonzero terms in the polynomial, Ni and aNi (i=1,2,⋯,K) are the exponents and coefficients, respectively. It is given that 1≤K≤10,0≤NK<⋯ Output Specification:
For each test case you should output the sum of A and B in one line, with the same format as the input. Notice that there must be NO extra space at the end of each line. Please be accurate to 1 decimal place.
Sample Input:
2 1 2.4 0 3.2
2 2 1.5 1 0.5
Sample Output:
3 2 1.5 1 2.9 0 3.2

题目大意:
  给定两个多项式求他们的和, 且按照 k (有 k 项), 第一项的指数, 第一项的系数 这一格式输入。且注意到是按照指数不减次序输入的。要求输出也是 有 n 项 第一项的指数,第一项的系数;且按照指数不减的次数输出。

思路:
  创建一个double 变量的静态数组 ans,每次读入 指数 exp 与系数temp。 且进行 ans[exp] += temp 的操作,即将系数temp 加到 相应位置上。

参考代码:

#include
const int maxn = 1010;
double ans [maxn];
int main (){
	int n, exp;
	double temp;
	scanf("%d", &n);
	for(int i = 0; i < n; ++i){
		scanf("%d %lf", &exp, &temp);
		ans[exp] += temp;
	}
	scanf("%d", &n);
	for(int i = 0; i < n; ++i){
		scanf("%d %lf", &exp, &temp);
		ans[exp] += temp;
	}
	int cnt = 0;
	for(int i = 0; i < maxn; ++i)
		if(ans[i] != 0)	cnt++;
	printf("%d", cnt);
	for(int i = maxn - 1; i >= 0; --i)
		if(ans[i] != 0)	printf(" %d %.1f", i, ans[i]);
	return 0;
}

 

你可能感兴趣的:(PAT甲级)