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

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

设计函数求一元多项式的导数。(注: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<stdio.h>
int main()
{
	int a,b;
	int flag = 0;
	while(scanf("%d %d",&a,&b)!=EOF)
	{
		if(b!=0)
		{
			if(flag == 0)
				printf("%d",a*b);
			else 
				printf(" %d",a*b);
			printf(" %d",b-1);
			flag = 1;
		}
	}
	if(flag==0)
		printf("0 0");
	return 0;
}

 ps1:通往大神博客的传送门:https://blog.csdn.net/qq_40167974/article/details/80766694

 ps2:代码分析:

1、flag用来判断是否已经有过输出
2、当b!=0时,因为给出的是所有非零项系数,所以必定会有输出,先判断flag是否为1,如果为1表示已经有过输出,那么在前面要先输出一个空格
3、输出 a * b 和 b – 1,然后将flag标记为1表示已经有过输出
4、最后判断当没有输出并且b==0的时候,输出“0 0”

ps3:

  • a为系数,b为指数,flag为判断是否已经输出过的标志,直接判断b是否为0,不为0的时候输出求导之后的值。
  • 其中这个flag的作用真的很大,不用写过多的判断语句来判断此时空格是否应该输入,只需要一个flag参数就可以完成:循环内部,最初b!=0,flag==0的话,首先输出的是a*b空格b-1,注意此时b-1后面是没有空格的,此时已经有输入了,flag变成1; 如果再进行循环,满足b!=0条件,此时flag==1,就在上一个b-1的后面加空格;如果flag==1,b=0的话,就不会再进行求导了,最后的那个数字也不会再加空格。然后再是对零多项式的判断:如果flag==0的话,就证明之前没有过输出,直接输出0 0,如果flag!=0的话,代表有过输出了,就不是零多项式 。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值