PAT B1010 一元多项式求导 (25分)

南笙酒味 提交于 2020-02-27 13:08:33

题目链接https://pintia.cn/problem-sets/994805260223102976/problems/994805313708867584

题目描述
设计函数求一元多项式的导数。(注:x^​ n ​​ ( n为整数)的一阶导数为nx^(​n−1)​​ 。)

输入
以指数递降方式输入多项式非零项系数和指数(绝对值均为不超过 1000 的整数)。数字间以空格分隔。

输出
以与输入相同的格式输出导数多项式非零项的系数和指数。数字间以空格分隔,但结尾不能有多余空格。注意“零多项式”的指数和系数都是 0,但是表示为 0 0。

样例输入
3 4 -5 2 6 1 -2 0

样例输出
12 3 -10 1 6 0

代码

#include <cstdio>

struct {
	int x, y;
}a[1001];

int main() {
	int t = 0, flag = 0;
	while(scanf("%d %d", &a[t].x, &a[t].y) != EOF)
		t++;
	for(int i = 0; i < t; i++) {
		if(a[i].y != 0) {
            if(i)
		        printf(" ");			//在前面加空格
			printf("%d %d", a[i].x * a[i].y, a[i].y - 1);
			flag = 1;

		}
	}
	if(flag == 0)
		printf("0 0");
	printf("\n");
	return 0;
}

【注】:注意没有输入限制的数据的处理
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!