数据结构C语言多项式相加代码
时间: 2024-04-21 13:19:29 浏览: 155
当涉及到多项式相加的问题时,我们可以使用链表来表示多项式,并通过遍历链表来实现相加操作。下面是一个用C语言实现多项式相加的代码示例:
```c
#include <stdio.h>
#include <stdlib.h>
// 定义多项式的节点结构
typedef struct Node {
int coefficient; // 系数
int exponent; // 指数
struct Node* next;
} Node;
// 创建一个新的节点
Node* createNode(int coefficient, int exponent) {
Node* newNode = (Node*)malloc(sizeof(Node));
newNode->coefficient = coefficient;
newNode->exponent = exponent;
newNode->next = NULL;
return newNode;
}
// 向多项式中插入一个节点
void insertNode(Node** poly, int coefficient, int exponent) {
Node* newNode = createNode(coefficient, exponent);
if (*poly == NULL) {
*poly = newNode;
} else {
Node* temp = *poly;
while (temp->next != NULL) {
temp = temp->next;
}
temp->next = newNode;
}
}
// 打印多项式
void printPolynomial(Node* poly) {
Node* temp = poly;
while (temp != NULL) {
printf("%dx^%d ", temp->coefficient, temp->exponent);
if (temp->next != NULL) {
printf("+ ");
}
temp = temp->next;
}
printf("\n");
}
// 相加两个多项式
Node* addPolynomials(Node* poly1, Node* poly2) {
Node* result = NULL;
Node* temp1 = poly1;
Node* temp2 = poly2;
while (temp1 != NULL && temp2 != NULL) {
if (temp1->exponent > temp2->exponent) {
insertNode(&result, temp1->coefficient, temp1->exponent);
temp1 = temp1->next;
} else if (temp1->exponent < temp2->exponent) {
insertNode(&result, temp2->coefficient, temp2->exponent);
temp2 = temp2->next;
} else {
int sum = temp1->coefficient + temp2->coefficient;
if (sum != 0) {
insertNode(&result, sum, temp1->exponent);
}
temp1 = temp1->next;
temp2 = temp2->next;
}
}
// 将剩余的节点添加到结果中
while (temp1 != NULL) {
insertNode(&result, temp1->coefficient, temp1->exponent);
temp1 = temp1->next;
}
while (temp2 != NULL) {
insertNode(&result, temp2->coefficient, temp2->exponent);
temp2 = temp2->next;
}
return result;
}
int main() {
Node* poly1 = NULL;
Node* poly2 = NULL;
Node* result = NULL;
// 创建第一个多项式
insertNode(&poly1, 3, 4);
insertNode(&poly1, 2, 3);
insertNode(&poly1, 5, 2);
insertNode(&poly1, 4, 0);
// 创建第二个多项式
insertNode(&poly2, 1, 3);
insertNode(&poly2, 2, 2);
insertNode(&poly2, 3, 1);
insertNode(&poly2, 6, 0);
printf("第一个多项式:");
printPolynomial(poly1);
printf("第二个多项式:");
printPolynomial(poly2);
result = addPolynomials(poly1, poly2);
printf("相加后的多项式:");
printPolynomial(result);
return 0;
}
```
这段代码使用了链表来表示多项式,每个节点包含了系数和指数。通过遍历两个多项式的链表,将相同指数的项相加,并将结果插入到新的链表中。最后打印出相加后的多项式。
阅读全文