数据结构课设——一元稀疏多项式的计算(单链表的应用)

本文介绍了一元稀疏多项式的计算,利用单链表存储结构体,包括系数、指数和指针域。通过用户菜单选择实现多项式的创建、输出、相加和相减操作。算法按照指数降序排列存储多项式项,处理特殊情况如系数为1、0或负数,指数为0、1的情况,并在相加相减时考虑指数大小关系。
摘要由CSDN通过智能技术生成

问题描述

能够按照指数降序排列建立并输出多项式;能够完成两个多项式的相加、相减,并将结果输出;

算法思想

       构建一个式子的结构体,包括系数,指数和指针域。分别输入各项的系数和指数,按照指数降序的方式存入到结构体链表中;输出多项式时,多项式为0,系数为1或是负数和指数为0或1,还有是否是最后一个式子的情况,都需要分别讨论;多项式相加即是若指数相等,则系数直接相加,不等则考虑将指数较大的一个式子存入和链表中。多项式相减与相加方法类似,但是要考虑指数较大的式子是被减数还是减数来决定是加号还是减号。

算法设计

1、菜单显示void menu()——供用户选择的功能菜单。

2、输出多项式void PrintfPolyn(Polynimial P)——输出多项式时,多项式为0,系数为1或是负数和指数为0或1,还有是否是最后一个式子的情况,都需要分别讨论。

3、建立多项式void CreatePolyn(Polynimial &P)——分别输入各项的系数和指数,按照指数降序的方式存入到结构体链表中。

4、多项式相加void AddPolyn(Polynimial P1,Polynimial P2)——则系数直接相加,不等则考虑将指数较大的一个式子存入和链表中。

5、多项式相减void MinusPolyn(Polynimial P1,Polynimial P2)——多项式相减与相加方法类似,但是要考虑指数较大的式子是被减数还是减数来决定是加号还是减号。

6、主函数int main()——使用while循环和switch对功能进行调用,使用清屏函数,使界面更美观。

代码实现

#include<stdio.h>//一元稀疏
  • 8
    点赞
  • 44
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值