数据结构实现两个多项式相加,用C语言完整代码实现
时间: 2024-10-07 12:01:14 浏览: 70
在C语言中,可以使用数组来表示多项式,每个元素代表系数,索引则对应于幂次。下面是使用结构体和指针实现两个多项式相加的简单示例:
```c
#include <stdio.h>
#include <stdlib.h>
typedef struct {
int degree; // 次数
double coefficient[100]; // 系数数组
} Polynomial;
// 功能:将两个多项式的系数相加
void addPolynomials(Polynomial *poly1, Polynomial *poly2) {
Polynomial temp;
if (poly1->degree > poly2->degree)
temp.degree = poly1->degree;
else
temp.degree = poly2->degree + 1;
for (int i = 0; i <= temp.degree; i++) {
if (i == 0 || (i != 0 && poly1->coefficient[i] != 0))
temp.coefficient[i] = poly1->coefficient[i];
if (i == 0 || (i != 0 && poly2->coefficient[i] != 0)) {
if (temp.coefficient[i])
temp.coefficient[i] += poly2->coefficient[i];
else
temp.coefficient[i] = poly2->coefficient[i];
}
}
*poly1 = temp;
}
// 主函数测试
int main() {
Polynomial poly1 = {5, {1.0, 2.0, 3.0}}, poly2 = {3, {4.0, 5.0, 6.0}}, result;
printf("Poly1: ");
for (int i = 0; i <= poly1.degree; i++)
if (poly1.coefficient[i]) printf("%d*x^%d + ", i, i);
printf("0\n");
printf("Poly2: ");
for (int i = 0; i <= poly2.degree; i++)
if (poly2.coefficient[i]) printf("%d*x^%d + ", i, i);
printf("0\n");
addPolynomials(&poly1, &poly2);
printf("Sum (Poly1 + Poly2):");
for (int i = 0; i <= poly1.degree; i++)
if (poly1.coefficient[i]) printf("%d*x^%d + ", i, i);
printf("0\n");
return 0;
}
```
在这个例子中,`addPolynomials` 函数接收两个指向`Polynomial`类型的指针,并通过比较它们的度数确定结果多项式的度。然后遍历并累加两个多项式的系数。
阅读全文