目录
数组与链表算法-数组与多项式
多项式数组表达式
C++代码
数组与链表算法-数组与多项式
多项式是数学中相当重要的表达方式,如果使用计算机来处理多项式的各种相关运算,那么通常使用数组或链表来存储多项式。
多项式数组表达式
假如一个多项,这个多项式
就被称为
次多项式。一个多项式如果使用数组结构存储在计算机中的话,表示法有以下两种:
(1)使用一个长度的一维数组来存放,数组的第一个位置存储多项式的最大指数
,数组之后的各个位置从指数
开始,依次递减按序存储对应项的系数:
        
存储在中,例如
,可转换为A数组来表示,例如:
        
使用这种表达法的优点是在计算机中运用时,对于多项式各种运算(如加法与乘法)的设计比较方便。不过,如果多项式的系数为多半为零,例如,就太浪费内存空间了。
C++代码
#include<iostream>
using namespace std;
void PolySum(int* arrA, int* arrB, int* arrResoult) {
	arrResoult[0] = arrA[0];
	for (int i = 1; i < arrA[0] + 2; i++) {
		arrResoult[i] = arrA[i] + arrB[i];		
	}
}
void PrintPoly(int* arr) {
	int MaxExp = arr[0];
	for (int i = 1; i < arr[0] +2; i++) {
		if (arr[i] != 0) {
			if (MaxExp != 0)
				cout << arr[i] << "X^" << MaxExp << " ";
			else
				cout << arr[i];
			if (MaxExp - 1 >= 0)
				cout << " + ";
		}
		MaxExp--;
	}
	cout << endl;
}
int main() {
	int* PolyA = new int[]{ 4,3,7,0,6,2 };
	int* PolyB = new int[]{ 4,1,5,2,0,9 };
	int* PolyResoult = new int[PolyA[0]+2] {0};
	cout << "多项式A:";
	PrintPoly(PolyA);
	cout << "多项式B:";
	PrintPoly(PolyB);
	PolySum(PolyA, PolyB, PolyResoult);
	cout << "A + B =  ";
	PrintPoly(PolyResoult);
	return 0;
}输出结果

(2)只存储多项式中的非零项。如果有个非零项,就使用
长的数组来存储每一个非零项的指数及系数,但数组的第一个元素存储的是这个多项式非零项的个数。
例如,可表示成
数组,如下所示:
        
这种方法的优点是在多项式零项较多时可以减少对内存空间的浪费,但缺点是在为多项式设计各种运算时会复杂许多。
使用多项式的两种数组表示法来存储多项式,结果如下:
注意,在上面这个例子中,第二种数组表示法并没有体现出减少对内存空间的浪费的优点,这是因为多项式的零项并不多,只是缺了
和
这两项。



![[导弹打飞机H5动画制作]飞机路线的随机起飞及自爆模拟](https://img-blog.csdnimg.cn/f56e0b36039347ff882d460398182dae.png)





![Kitex踩坑 [Error] KITEX: processing request error,i/o timeout](https://img-blog.csdnimg.cn/cb3a490b2ba943d5b4e6edb18a1b1095.png)





![[SpringCloud] Nacos 简介](https://img-blog.csdnimg.cn/8cbdced4ed6b411ea71148af60c45222.png)



