02-线性结构2 一元多项式的乘法与加法运算

这篇博客介绍了如何使用C语言实现多项式链表,包括多项式的输入、插入操作,以及两个多项式的求和与乘积。通过链表结构动态存储多项式,并提供了详细的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

结果:
在这里插入图片描述

具体后面有时间再写吧,要找时间复习一下指针和结构体之类的了。

#include<stdio.h>
#include<stdlib.h>

typedef struct PolyomialNode* PolyomialType;

struct PolyomialNode
{
    int coef;//系数coefficient
    int expon; //指数
    PolyomialType link;
};

PolyomialType input_init(int N) //接收输入
{
    PolyomialType P = (PolyomialType)malloc(sizeof(struct PolyomialNode));
    PolyomialType Header = NULL;
    PolyomialType S = NULL;

    for (int i = 0; i < N; i++)
    {
        S = (PolyomialType)malloc(sizeof(struct PolyomialNode));
        while(!scanf("%d", &(S->coef)));
        while(!scanf("%d", &(S->expon)));
        P->link = S;
        P = S;
        if (Header==NULL)
            Header = S;
    }
    S = (PolyomialType)malloc(sizeof(struct PolyomialNode));
    S->link = NULL;
    P->link = S;//使得链表最后一个元素时指向NULL
    P = S;
    //此处若直接P.link=NULL则会漏掉最后一个数
    return Header;
}

void Insert(PolyomialType *P, int expon, int coef) //插入元素
{
    PolyomialType S = NULL;
    S = (PolyomialType)malloc(sizeof(struct PolyomialNode));
    S->expon = expon;
    S->coef = coef;
    S->link = NULL;
    (*P)->link = S;
    (*P) = S;
    return ;
}

PolyomialType Sum(PolyomialType T1, PolyomialType T2) //求和多项式
{
    PolyomialType P = (PolyomialType)malloc(sizeof(struct PolyomialNode));
    PolyomialType S = NULL, Header = P;
    // PolyomialType T1 = *P1, T2 = *P2;

    while (T2->link && T1->link) //两边同时不为空时
    {
        if (T1->expon == T2->expon)
        {
            if((T1->coef+T2->coef)!=0) //同类项合并时有抵消则不添加
                Insert(&P, T1->expon, T1->coef+T2->coef);
            T1 = T1->link;
            T2 = T2->link;
        }
        else if(T1->expon > T2->expon)
        {
            Insert(&P, T1->expon, T1->coef);
            T1 = T1->link;
        }
        else if(T1->expon < T2->expon)
        {
            Insert(&P, T2->expon, T2->coef);
            T2 = T2->link;
        }
    }
    while (T2->link)
    {
        Insert(&P, T2->expon, T2->coef);
        T2 = T2->link;
    }
    while (T1->link)
    {
        Insert(&P, T1->expon, T1->coef);
        T1 = T1->link;
    }

    S = (PolyomialType)malloc(sizeof(struct PolyomialNode));
    S->link = NULL;
    P->link = S;//使得链表最后一个元素时指向NULL
    P = S;
    return Header->link;
}

PolyomialType Multiply(PolyomialType P1, PolyomialType P2) //求乘积多项式
{
    PolyomialType Sum_P = (PolyomialType)malloc(sizeof(struct PolyomialNode));
    Sum_P->link = NULL;
    PolyomialType S = NULL;
    PolyomialType T1 = P1, T2 = P2;

    while (T2->link) //两边同时不为空时
    {
        PolyomialType P = (PolyomialType)malloc(sizeof(struct PolyomialNode));
        P->link = NULL;
        PolyomialType S = NULL, Headers = P;
        
        while (T1->link)
        {
            Insert(&P, T1->expon+T2->expon, T1->coef*T2->coef);
            T1 = T1->link;
        }
        S = (PolyomialType)malloc(sizeof(struct PolyomialNode));
        S->link = NULL;
        P->link = S;//使得链表最后一个元素时指向NULL
        Sum_P = Sum(Sum_P,Headers->link);
        free(P);
        T2 = T2->link;
        T1 = P1;
    }

    return Sum_P;
}

int main()
{
    int N = 0;
    PolyomialType P1 = (PolyomialType)malloc(sizeof(struct PolyomialNode));
    PolyomialType P2 = (PolyomialType)malloc(sizeof(struct PolyomialNode));
    PolyomialType S;

    while(!scanf("%d",&N));
    if(N==0)//输入为零项时
    {
        P1->coef = 0;
        P1->expon = 0;
        S = (PolyomialType)malloc(sizeof(struct PolyomialNode));
        S->link = NULL;
        P2->link = S;//使得链表最后一个元素时指向NULL
    }
    else P1 = input_init(N);

    while(!scanf("%d",&N));
    if(N==0)
    {
        P2->coef = 0;
        P2->expon = 0;
        S = (PolyomialType)malloc(sizeof(struct PolyomialNode));
        S->link = NULL;
        P2->link = S;//使得链表最后一个元素时指向NULL
    }
    else P2 = input_init(N);

    PolyomialType Sum_P = Sum(P1, P2);
    PolyomialType Multiply_P = Multiply(P1, P2);

    if(!Multiply_P->link) // 系数和指数取上限,结果有零多项式
    {
        printf("0 0");
    }
    else
        while (Multiply_P->link)
        {
            printf("%d %d", (*Multiply_P).coef, (*Multiply_P).expon);
            Multiply_P = Multiply_P->link;
            if(Multiply_P->coef==0 && Multiply_P==0)
                break;
            if(Multiply_P->link)
                printf(" ");
        }
    printf("\n");
    if(!Sum_P->link) // 系数和指数取上限,结果有零多项式
        printf("0 0");
    while (Sum_P->link)
    {
        printf("%d %d", (*Sum_P).coef, (*Sum_P).expon);
        Sum_P = Sum_P->link;
        if(Multiply_P->coef==0 && Multiply_P==0)
            break;
        if(Sum_P->link)
            printf(" ");
    }
    
    return 0;
}
《C++编程实例100篇》是一本深入实践、极具价值的编程教程,它针对C++编程语言提供了丰富的实例,旨在帮助读者更好地理解和掌握C++的各项特性编程技巧。这本书的经典之处在于它将理论实践相结合,通过100个精心设计的编程实例,覆盖了C++的各个核心领域,包括基础语法、面向对象编程、模板、异常处理、STL(标准模板库)等。 我们来探讨C++的基础语法。C++是C语言的增强版,它保留了C语言的高效性和灵活性,并引入了类、对象和继承等面向对象编程概念。基础语法包括变量声明、数据类型、运算符、控制结构(如if语句、for循环、while循环)、函数的定义和调用等。在实例中,你可能会遇到如何编写简单的程序,如计算两个数的和,或者实现一个简单的猜数字游戏。 C++的面向对象编程是其一大特色。通过类和对象,你可以构建复杂的软件系统。类是对象的蓝图,它定义了对象的属性和行为。实例化一个类,就是创建一个具体的对象。继承允许你创建新的类,这些类从现有的类派生,共享其属性和方法,同时可以添加新的功能。多态性是面向对象的另一个关键特性,它使得不同类型的对象可以对同一消息作出不同的响应。这些概念在实例中会以各种形式展现,例如设计一个图形界面的类层次,或实现一个简单的模拟游戏。 接下来是模板,C++的模板功能让代码更加通用,可以处理不同类型的数据。模板分为函数模板和类模板,前者可以创建泛型函数,后者可以创建泛型类。通过模板,你可以编写出高效且灵活的代码,比如实现一个通用的排序算法。 异常处理是C++中用于处理程序运行时错误的机制。当程序出现异常情况时,可以抛出一个异常,然后在适当的点捕获并处理这个异常。这使得代码能够优雅地处理错误,而不是让程序崩溃。实例中可能会有涉及文件操作或网络通信时可能出现的异常处理示例。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值