天天看点

PAT乙级真题及训练集(9)--1010. 一元多项式求导 1010. 一元多项式求导 (25)

1010. 一元多项式求导 (25)

时间限制 400 ms

内存限制 65536 kB

代码长度限制 8000 B

判题程序 Standard

设计函数求一元多项式的导数。(注:xn(n为整数)的一阶导数为n*xn-1。)

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

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

输入样例:

3 4 -5 2 6 1 -2 0
      

输出样例:

12 3 -10 1 6 0      
/**
作者:一叶扁舟
时间:14:48 2017/6/17
思路:

*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define SIZE 1000 * 2

int main(){
	int d = 0;//系数
	int e = 1;//指数
	int data[SIZE];
	int a, b;
	int count = 0;
	while (scanf("%d %d", &a, &b) != EOF){
		//首先判断指数是不是为0
		if (b != 0){
			data[d] = a * b;
			data[e] = b - 1;
			d += 2;
			e += 2;
			count++;
		}
		else{
			break;
		}
	}
	//如果输入的是常数则对应的求导之后为 0 0,陷阱
	if (count == 0){
		printf("0 0");
	}
	//输出结果
	for (int i = 0; i < count * 2; i++){
		printf("%d",data[i]);
		if (i != count * 2 -1){
			printf(" ");
		}
	}
	system("pause");
	return 0;
}