Java 算法 一元多项式求导

题目描述

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

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

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

输入样例 1
3 4 -5 2 6 1 -2 0
原公式:3X4-5X2+6X1-2X0

输出样例 1
12 3 -10 1 6 0
求导后:12X3-10X1+6X0

输入样例 2

6 0
输出样例 2

0 0
输入样例 3

0 0
输出样例 3

0 0

解题思路

就是普通的导数计算,但要分两种情况,一种为只有常数的和含有未知数的,常数的直接输出“0 0”,其余的计算后加入列表再依次输出就行,注意最后的数字后面没有空格,还有就是输入没有具体的值,可以通过先输入字符再将其转换为数字。

代码

import java.util.ArrayList;
import java.util.Scanner;

public class Main {
    static int b=0,c=0;
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        String m=scanner.nextLine();            //不知道具体的输入个数 先输入字符串
        String []n=m.split(" ");         //然后通过空格切分 放入数组中
        ArrayList<Integer> a=new ArrayList<>();
        for (int i=0;i<n.length;i+=2){
            if (n.length==2&&Integer.parseInt(n[1])==0){    //若只有常数则直接输出“0 0”
                System.out.println("0 0");
            }
            if (Integer.parseInt(n[i+1])==0){           //若多次项只剩常数结束循环
                break;
            }
            b=Integer.parseInt(n[i])*Integer.parseInt(n[i+1]);  //其余的让指数乘以常数 指数再减一
            c=Integer.parseInt(n[i+1])-1;
            a.add(b);                                     //添加进列表
            a.add(c);
            b=0;
            c=0;
        }
        for (int j:a){                                      //循环输出
            if (j!=0){                                      //最后一个数后不加空格
                System.out.print(j+" ");
            }else {
                System.out.print(j);
            }
        }
    }
}
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

future furuer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值