1多项式加法(5分)

2017-12-22  本文已影响0人  Ming_0612

题目内容:
一个多项式可以表达为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();      
    }
}

上一篇下一篇

猜你喜欢

热点阅读