数据结构实验(共7页).doc
《数据结构实验(共7页).doc》由会员分享,可在线阅读,更多相关《数据结构实验(共7页).doc(8页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、精选优质文档-倾情为你奉上实验一 一元多项式的表示和相减、相乘实验人: 学号: 时间: 一、实验目的1. 掌握链表的存储方式2. 掌握一元多项式的存储及运算。二、实验内容已知一元多项式P(x)和Q(x)已存在,求P(x)-Q(x)和P(x)* Q(x)并输出。要求:1.通过键盘随机输入两多项式P(x)和Q(x)的内容。2.输出结果要有P(x)和Q(x)的以及它们的差P(x)-Q(x)和乘积P(x)* Q(x)。三、实验步骤:1. 创建一元多项P(x)和Q(x)。2. 求P(x)-Q(x),P(x)* Q(x)。3. 输出P(x)、Q(x)、P(x)-Q(x),P(x)* Q(x)。四、算法说明
2、首先,定义一元多项式的存储方式,然后从键盘输入P(x)和Q(x)对应多项式的各对系数和指数,建立相应的一元多项式;其次进行多项数加法时,新建一个存储结果的链表,分别将两多项式各项依次插入结果多项式即完成多项式相加运算,得到P(x)+Q(x)的结果;进行多项数加法时,将减项多项式各项系数化为相反数后进行加法操作,即完成多项式相减运算,得到P(x)-Q(x)的结果。最后进行多项式乘法时,创建双循环结构,将两多项式各项依次相乘,并将每两项相乘结果有序插入到储存运算结果的多项式链表中,最后得到P(x)*Q(x)的结果。五、测试结果参考下图(测试数值不要一样)六、源代码#include# include
3、typedef struct float coef; /多项式的系数 int expn; /多项式的指数ElemType;typedef struct LNode /结点类型 ElemType data; struct LNode *next;*LinkList; /线性表的单链表存储结构void MakeNode(LinkList &s,ElemType e) /生成结点 s=(LinkList)malloc(sizeof(LNode); s-data=e;void InsAfter(LinkList p,LinkList s) /插入结点 s-next=p-next; p-next=s;i
4、nt compare(ElemType e1,ElemType e2) /比较 if(e1.expne2.expn) return 1; else if(e1.expnnext,s; int n; while(q) n=compare(e,q-data); if(ndata.coef=q-data.coef+e.coef; if(q-data.coef=0)p-next=q-next;free(q); break; p=p-next;q=p-next; if(q=NULL) MakeNode(s,e); InsAfter(p,s);/最大,放在最后一个位置 void IntList(LinkL
5、ist &L) /初始化链表 L=(LinkList)malloc(sizeof(LNode); L-next=NULL;void SetCurElem(LinkList &L,ElemType e) /设置结点 L-data.coef=e.coef; L-data.expn=e.expn;void CreatePolyn(LinkList &L,int m)ElemType e;e.coef=0.0;e.expn=-1; IntList(L); SetCurElem(L,e);/设置头结点的数据元素 printf(请输入%d对多项式的值:n,m); for(int i=1;inext;if(
6、p) /第一个输出printf(%.2fX%d,p-data.coef,p-data.expn); p=p-next;while(p) if(p-data.coef0) printf(+); printf(%.2fX%d,p-data.coef,p-data.expn); p=p-next; printf(n); void ListDestory(LinkList &L) /销毁 LinkList p=L,q;while(p)q=p;p=p-next;free(q); void Add(LinkList L1,LinkList L2,LinkList &L3) /多项式相加 ElemType
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 实验
限制150内