在Java中使用LinkedList添加两个多项式

时间:2016-10-26 12:44:16

标签: java list polynomials

我的任务是创建一个程序,使用LinkedList数据结构添加两个多项式,到目前为止,我已经编写了添加和接受两个多项式的代码。我的问题是,在用户输入其多项式后,应该会发生添加,但返回的多项式的值始终为0x ^ 0.

这是程序的主要代码。(注意:这是在一个开关的情况下,所以我没有把整个方法。)

System.out.println("Literal Coefficient of the two Polynomials: \'x\'");
System.out.println("Degree of the first Polynomial?");
System.out.print("Input: ");
    eV = readInteger();
    nC = new int[eV];
        for(int x=0; x<=nC.length-1; x++) {
            System.out.println("Numerical Coefficient of the term with Degree "+eV+"?");
            System.out.print("Input: ");
            nC[x] = readInteger();

            firstPoly.add(new Term(nC[x], eV, 'x'));

            eV--;
        }
resultPolyOne.setTerms(firstPoly);
System.out.println();   
System.out.println("The first Polynomial entered: ");
stringRepresentation(firstPoly);
System.out.println();
System.out.println();
System.out.println("Degree of the second Polynomial?");
System.out.print("Input: ");
    eV = readInteger();
    nC = new int[eV];
        for(int x=0; x<=nC.length-1; x++) {
            System.out.println("Numerical Coefficient of the term with Degree "+eV+"?");
            System.out.print("Input: ");
            nC[x] = readInteger();

            secondPoly.add(new Term(nC[x], eV, 'x'));

            eV--;
        }
resultPolyTwo.setTerms(firstPoly);    
System.out.println();   
System.out.println("The second Polynomial entered: ");
stringRepresentation(secondPoly);
System.out.println();
System.out.println();  
System.out.println("Result of the Addition: ");
System.out.println((resultPolyOne.addPolys(resultPolyTwo)).toString());

firstPoly.clear();
secondPoly.clear();

添加多项式的方法

public Polynomial addPolys(Polynomial otherPoly) throws Exception {
    LinkedList<Term> resultTerms = new LinkedList<Term>();
    Polynomial resultPoly = new Polynomial();
        for(int x=0; x<this.getTerms().size(); x++) {
            Term currentTerm = this.getTerms().get(x);
            resultTerms.add(new Term(currentTerm.getNumC(), currentTerm.getExpC(), currentTerm.getLitC()));
        }
        resultPoly.setTerms(resultTerms);
        for(int y=0; y<otherPoly.getTerms().size(); y++) {
            resultPoly.addTerm(otherPoly.getTerms().get(y));
        } 
        if(resultPoly.getTerms().size()==0) {
            resultPoly.addTerm(new Term(0,0,'x'));
        }
return resultPoly;
}//addPolys

将术语添加到多项式

的方法
public void addTerm(Term newTerm) throws Exception {
    int listIndex = 00;
    boolean foundFlag = false;
    Term currentTerm = null;

    for(listIndex=0; listIndex<polyTerm.size(); listIndex++) {
        currentTerm = polyTerm.get(listIndex);
            if(currentTerm.getExpC()<=newTerm.getExpC()) {
                foundFlag = true;
                break;
            }
    }
    if(!foundFlag) {
        polyTerm.add(newTerm);
    } else {
        if(currentTerm.getExpC()<newTerm.getExpC()) {
            polyTerm.add(listIndex, newTerm);
        } else {
            currentTerm.setNumC(currentTerm.getNumC()+newTerm.getNumC());
            if(currentTerm.getNumC()==0) {
                polyTerm.remove(listIndex);
            }
        }
    }
}//addTerm

添加,我的Term的构造函数是这样的。

Term(int numberCoefficent, char literalCoefficent, int exponentialCoefficient) {
    //Codes here
}

1 个答案:

答案 0 :(得分:0)

感谢@GhostCat,我最后回顾了我的问题,并试图改进它,结果我找到了我的问题的答案。

@MordechayS问题出在我显示多项式的行内。 @matt我会发布我的答案,所以我想不再需要帮助了。

问题在于:

System.out.println((resultPolyOne.addPolys(resultPolyTwo)).toString());

我替换为:

resultPolyThree.toStringRep();

这是我在Polynomial Class中创建的一个方法,我没有覆盖Object的toString方法,因为我想对此进行改进。