美文网首页
1多项式加法(5分)

1多项式加法(5分)

作者: Ming_0612 | 来源:发表于2017-12-22 00:16 被阅读0次

题目内容:
一个多项式可以表达为x的各次幂与系数乘积的和,比如:
2x6+3x5+12x3+6x+20
现在,你的程序要读入两个多项式,然后输出这两个多项式的和,也就是把对应的幂上的系数相加然后输出。
程序要处理的幂最大为100。

输入格式:
总共要输入两个多项式,每个多项式的输入格式如下:
每行输入两个数字,第一个表示幂次,第二个表示该幂次的系数,所有的系数都是整数。第一行一定是最高幂,最后一行一定是0次幂。
注意第一行和最后一行之间不一定按照幂次降低顺序排列;如果某个幂次的系数为0,就不出现在输入数据中了;0次幂的系数为0时还是会出现在输入数据中。

输出格式:
从最高幂开始依次降到0幂,如:
2x6+3x5+12x3-6x+20
注意其中的x是小写字母x,而且所有的符号之间都没有空格,如果某个幂的系数为0则不需要有那项。

输入样例:
6 2
5 3
3 12
1 6
0 20
6 2
5 3
2 12
1 6
0 20

输出样例:
4x6+6x5+12x3+12x2+12x+40
时间限制:500ms内存限制:32000kb

package pro;

import java.util.Scanner;

public class main3 {
    public static void main(String[] args) {
        int[]a=new int[101];
        int[]b=new int [101];
        Scanner scan=new Scanner(System.in);
        int next;//保存输入值
        boolean flag1=false;//前面都有数
        boolean flag2=false;//前面都有数
        
        while((next=scan.nextInt())!=0) {
            a[next]+=scan.nextInt();
        }
        a[0]+=scan.nextInt();
        
        while((next=scan.nextInt())!=0) {
            b[next]+=scan.nextInt();
        }
        b[0]+=scan.nextInt();
        //输出最高幂次项(大于2)+x6和x6
        //要考虑:1.系数是负数2.系数是正负一时,不输出一
        int i=100;
        for(;i>=2;--i) {
            if(a[i]+b[i]!=0) {
                System.out.print((a[i]+b[i]>0?"":"-")+(Math.abs(a[i]+b[i])==1?"":Math.abs(a[i]+b[i]))+"x"+i);
                flag1=true;
                flag2=true;
                break;
            }
        }
        --i;
        //系数不为零时和x平方及以上,要考虑:1.正负2.正负一  x6+1x2和x6+x2
        for(;i>=2;--i) {
            if(a[i]+b[i]!=0) {
                System.out.print((a[i]+b[i]>0?"+":"-")+(Math.abs(a[i]+b[i])==1?"":Math.abs(a[i]+b[i]))+"x"+i);
            }
                
        }
       //若有最高次项(大于1次), 则一次方的项的输出,x2+1x和x2+x
       if(flag1) {
           if(a[1]+b[1]!=0) {
                System.out.print((a[1]+b[1]>0?"+":"-")+(Math.abs(a[1]+b[1])==1?"":Math.abs(a[1]+b[1]))+"x");
                flag2=true;
             }
       }
       //若没有最高次项,一次方项的输出,+x和x
       else {
           if(a[1]+b[1]!=0) {
                System.out.print((a[1]+b[1]>0?"":"-")+(Math.abs(a[1]+b[1])==1?"":Math.abs(a[1]+b[1]))+"x");
                flag1=true;
                flag2=true;
           }
       }
       //若最高次项为一次x+8,和8的区别
        if(flag1) {
             if(a[0]+b[0]!=0) {
                System.out.print((a[0]+b[0]>0?"+":"-")+Math.abs(a[0]+b[0]));
                flag2=true;
               }     
        }else {
            if(a[0]+b[0]!=0) {
                System.out.print((a[0]+b[0]>0?"":"-")+Math.abs(a[0]+b[0]));
                flag2=true;
              }     
        }
        //两个多项式都为0
        if(!flag2) {
            System.out.print(0);
        }
            
        scan.close();      
    }
}

相关文章

  • 一元多项式

    1 、问题描述: 功能:设计一个一元多项式加法器。 输入并建立多项式,实现两个多项式的加法运算。 要求: 1) 界...

  • 第4章编程题

    多项式加法

  • Java 数组 编程练习题

    1、 多项式加法 题目内容: 一个多项式可以表达为x的各次幂与系数乘积的和,比如: 现在,你的程序要读入两个多项式...

  • 多项式加法

    第一篇markdown,练习以下. 一个人对痛苦的感受能力和对无聊的感受能力成反比,这是由一个人的精神能力的大小决...

  • 1多项式加法(5分)

    题目内容:一个多项式可以表达为x的各次幂与系数乘积的和,比如:2x6+3x5+12x3+6x+20现在,你的程序要...

  • JAVA作业5

    1多项式加法(5分) 题目内容: 一个多项式可以表达为x的各次幂与系数乘积的和,比如: 2x6+3x5+12x3+...

  • 4 数组-[Java学习笔记]

    习题 1 多项式加法(5分)题目内容:一个多项式可以表达为x的各次幂与系数乘积的和,比如:2x6+3x5+12x3...

  • 第7周编程练习

    1.多项式加法(5分) 题目内容:一个多项式可以表达为x的各次幂与系数乘积的和,比如:2x6+3x5+12x3+6...

  • 线性结构-相关算法

    编译环境:python v3.5.0, mac osx 10.11.4 多项式加法与乘法运算(队列) 主要思路: ...

  • 多项式加减法 (二)

    在多项式加法 (一)中,我们介绍了多项式对应的单链表的几个接口,现在我们来完成本次实验剩余的其他几个接口。 第五步...

网友评论

      本文标题:1多项式加法(5分)

      本文链接:https://www.haomeiwen.com/subject/xcnzwxtx.html