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

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

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

输入样例:

3 4 -5 2 6 1 -2 0
结尾无空行

输出样例:
12 3 -10 1 6 0
结尾无空行

代码如下:

#include <stdio.h>
#include <string.h>
#define N 1001
int main()
{
	int A[N]={0},B[N]={0},C[N]={0},D[N]={0},i,j,n;
	char c='1';
	for (i=0;c!='\n';i++)
		scanf("%d %d%c",&A[i],&B[i],&c);
	for (n=0;n<i;n++)
	{
		C[n]=A[n]*B[n];
		D[n]=B[n]-1;
	}
	for (j=0;j<i;j++)
	{
		if (B[0]==0)
		{
			printf("0 0");
			break;
		}
		printf("%d %d",C[j],D[j]);
		if (B[j+1]==0)
			break;
		if (j!=i-1)//或者else也可 
		    printf(" ");
	}
	return 0;
}

注意点:
1.输入中含负数,用GETS获取字符串不易转换,不如用scanf与%c连用吃掉空格,并通过循环记数
2.初始化c为非零字符,否则一上来就打断
3.判断中,首当其冲控制输入为“x 0”情况(即常数项);其次输出正常;然后在结尾的空格处,限制当B的下一位为0时,终止,否则输出空格

运行结果:
1010 一元多项式求导 (25 分)

上一篇:E-简单排序


下一篇:Bzoj 2969 矩阵粉刷