早教吧作业答案频道 -->其他-->
Java数据结构编程题目一条单链表可以表示一个一元多项式,每个结点包括三个域:指数域、系数域和后继结点链。表示多项式3x(4次方)-6x(2次方)+5x-10的单链表。给定两个多项式,实现两个多
题目详情
Java数据结构编程题目
一条单链表可以表示一个一元多项式,每个结点包括三个域:指数域、系数域和后继结点链。表示多项式3x(4次方)-6x(2次方)+5x-10的单链表。给定两个多项式,实现两个多项式相加算法。(最好有详细解析,如果解析的好会再加分)
一条单链表可以表示一个一元多项式,每个结点包括三个域:指数域、系数域和后继结点链。表示多项式3x(4次方)-6x(2次方)+5x-10的单链表。给定两个多项式,实现两个多项式相加算法。(最好有详细解析,如果解析的好会再加分)
▼优质解答
答案和解析
自己参考下吧,希望对你有用!
//用单链表来实现多项式的加法,代码如下
public class Polynomial {
private Monomial first; // 首项
// 添加单项式
public void append(Monomial monomial) {
if (monomial == null) {
// do nothing
} else if (first == null) {
first = monomial;
} else {
Monomial current = first;
while (current != null) {
// 提示:如果指数相同,则相加
if (current.index == monomial.index) {
current.coefficient += monomial.coefficient;
break;
} else if (current.next == null) { // 否则直接把此项扔到最后
current.next = monomial;
break;
}
current = current.next;
}
}
}
public void append(int c, int i) {
append(new Monomial(c, i));
}
public String toString() {//toString()方法就是把对象转换成String类型
//比如一个Integer对象的toString方法就是把这个对象表示的整数转化成字符串,133就成了"133"。
StringBuffer sb = new StringBuffer();
Monomial current = first;
while (current.next != null) {
sb.append("(" + current.coefficient + "x^" + current.index
+ ") + ");
current = current.next;
}
sb.append("(" + current.coefficient + "x^" + current.index + ")");
return sb.toString();
}
// 两个多项式相加
public Polynomial add(Polynomial p2) {
Polynomial result = new Polynomial();
Monomial current = this.first;
while (current != null) {
result.append(current.coefficient, current.index); // 提示:注意这里
current = current.next;
}
current = p2.first;
while (current != null) {
result.append(current.coefficient, current.index);
current = current.next;
}
return result;
}
public static void main(String[] args) {
//构造多项式p1的每一项
Polynomial p1 = new Polynomial();
p1.append(3, 4);
p1.append(-6, 2);
p1.append(5, 1);
p1.append(-10, 0);
System.out.println("p1: " + p1);
//构造多项式p2的每一项
Polynomial p2 = new Polynomial();
p2.append(2, 5);
p2.append(-6, 2);
p2.append(5, 1);
System.out.println("p2: " + p2);
Polynomial result = p1.add(p2);
System.out.println("p1+p2= " + result);
}
}
/**
* 这是一个内部类
* 单项式的表示
*/
class Monomial {
int coefficient; // 系数
int index; // 指数
Monomial next; // 后继结点
public Monomial() {
}
public Monomial(int c, int i) {
this.coefficient = c;
this.index = i;
}
}
//用单链表来实现多项式的加法,代码如下
public class Polynomial {
private Monomial first; // 首项
// 添加单项式
public void append(Monomial monomial) {
if (monomial == null) {
// do nothing
} else if (first == null) {
first = monomial;
} else {
Monomial current = first;
while (current != null) {
// 提示:如果指数相同,则相加
if (current.index == monomial.index) {
current.coefficient += monomial.coefficient;
break;
} else if (current.next == null) { // 否则直接把此项扔到最后
current.next = monomial;
break;
}
current = current.next;
}
}
}
public void append(int c, int i) {
append(new Monomial(c, i));
}
public String toString() {//toString()方法就是把对象转换成String类型
//比如一个Integer对象的toString方法就是把这个对象表示的整数转化成字符串,133就成了"133"。
StringBuffer sb = new StringBuffer();
Monomial current = first;
while (current.next != null) {
sb.append("(" + current.coefficient + "x^" + current.index
+ ") + ");
current = current.next;
}
sb.append("(" + current.coefficient + "x^" + current.index + ")");
return sb.toString();
}
// 两个多项式相加
public Polynomial add(Polynomial p2) {
Polynomial result = new Polynomial();
Monomial current = this.first;
while (current != null) {
result.append(current.coefficient, current.index); // 提示:注意这里
current = current.next;
}
current = p2.first;
while (current != null) {
result.append(current.coefficient, current.index);
current = current.next;
}
return result;
}
public static void main(String[] args) {
//构造多项式p1的每一项
Polynomial p1 = new Polynomial();
p1.append(3, 4);
p1.append(-6, 2);
p1.append(5, 1);
p1.append(-10, 0);
System.out.println("p1: " + p1);
//构造多项式p2的每一项
Polynomial p2 = new Polynomial();
p2.append(2, 5);
p2.append(-6, 2);
p2.append(5, 1);
System.out.println("p2: " + p2);
Polynomial result = p1.add(p2);
System.out.println("p1+p2= " + result);
}
}
/**
* 这是一个内部类
* 单项式的表示
*/
class Monomial {
int coefficient; // 系数
int index; // 指数
Monomial next; // 后继结点
public Monomial() {
}
public Monomial(int c, int i) {
this.coefficient = c;
this.index = i;
}
}
看了 Java数据结构编程题目一条...的网友还看了以下:
一.3的11次方表示成K项连续正整数的和,则项数K的最大值为A.594B.486C.374D.243 2020-03-30 …
数列的第一项是2,第二项能算出是2的3次方,第三项是2的(3^2)次方,求第100项数列的第一项是 2020-04-27 …
回答这些代数式的项数和次数:负xy平方加3xy平方;3a平方加2a加3;负4ab加8减2b平方减9 2020-05-17 …
如何在整式中找出系数、次数和项数?如何判断是单项式还是多项式?像4a的2次方b的2次方是单项式or 2020-07-31 …
已知正项数列an前n项和为sn,sn平方=a1三次方+a2三次方+an三次方.求证数列an为等差数 2020-07-31 …
求多项式的项数的公式如(a+b+c+d)的10次方有多少项?有公式直接计算吗?求多项式项数的各系数 2020-07-31 …
紧急求助一元二次方程,化方程为一般形式并写出二次项系数、一次项系数及常数项.将方程(x-2)(x- 2020-08-01 …
已知(1-2x)^n的展开式中,奇数项的二项式系数之和为64,则(1-2x)^n(1+x)的展开式 2020-08-03 …
Sn数列an前n项和Sn=(an+1)^2/4(an>0)不要用Sn-S(n-1)的方法,请用先求S 2020-12-05 …
高中数学数列的项数问题请问,有没有算数列(等差和等比)项数的公式?还有这几题怎么算项数?1、1+3+ 2021-02-09 …