一元多项式相加完整实验报告Word文档格式.docx

上传人:b****2 文档编号:15098859 上传时间:2022-10-27 格式:DOCX 页数:10 大小:104.65KB
下载 相关 举报
一元多项式相加完整实验报告Word文档格式.docx_第1页
第1页 / 共10页
一元多项式相加完整实验报告Word文档格式.docx_第2页
第2页 / 共10页
一元多项式相加完整实验报告Word文档格式.docx_第3页
第3页 / 共10页
一元多项式相加完整实验报告Word文档格式.docx_第4页
第4页 / 共10页
一元多项式相加完整实验报告Word文档格式.docx_第5页
第5页 / 共10页
点击查看更多>>
下载资源
资源描述

一元多项式相加完整实验报告Word文档格式.docx

《一元多项式相加完整实验报告Word文档格式.docx》由会员分享,可在线阅读,更多相关《一元多项式相加完整实验报告Word文档格式.docx(10页珍藏版)》请在冰豆网上搜索。

一元多项式相加完整实验报告Word文档格式.docx

VoidAddPolyn(polynomail&

Pa,polynomail&

Pb)

PositionGetHead()

PositionNextPos(LinkListL,Linkp)

ElemGetCurElem(Linkp)

intcmp(termatermb)

StatusSetCurElem(Link&

p,ElemTypee)

StatusDelFirst(Linkh,Link&

q)

StatusListEmpty(LinkListL)

StatusAppend(LinkList&

L,LinkS)

FreeNode()

2存储结构

一元多项式的表示在计算机内用链表来实现,同时为了节省存储空间,只存储其中非零的项,链表中的每个节点存放多项式的系数非零项。

它包含三个域,分别存放多项式的系数,指数,以及指向下一个项的指针。

序数coef

指数exp

指针域next

创建一元多项式链表,对运算中可能出现的各种情况进行分析,实现一元多项式的相加相减操作。

3模块划分

a)主程序;

2)初始化单链表;

3)建立单链表;

4)相加多项式

4主程序流程图

四详细设计

根据一元多项式相加的运算规则:

对于两个一元多项式中所有指数相同的项,对应系数相加,若其和不为零,则构成“和多项式”中的一项,对于两个一元多项式中所有指数不相同的项,则分别复抄到“和多项式”中去。

核心算法PolyAdd是把分别由pa和pb所指的两个多项式相加,结果为pa所指的多项式。

运算规则如下:

相加时,首先设两个指针变量qa和qb分别从多项式的首项开始扫描(见图2-5-1),比较qa和qb所指结点指数域的值,可能出现下列三种情况之一:

(1)qa->

exp大于qb->

exp,则qa继续向后扫描。

(2)qa->

exp等于qb->

exp,则将其系数相加。

若相加结果不为零,将结果放入qa->

coef中,并删除qb所指结点,否则同时删除qa和qb所指结点。

然后qa、qb继续向后扫描。

(3)qa->

exp小于qb->

exp,则将qb所指结点插入qa所指结点之前,然后qa、qb继续向后扫描。

扫描过程一直进行到qa或qb有一个为空为止,然后将有剩余结点的链表接在结果表上。

所得pa指向的链表即为两个多项式之和。

五源程序代码

#include<

stdio.h>

malloc.h>

stdlib.h>

#defineNULL0

typedefstructNODE{

floatcoef;

//系数

intexpn;

//指数

structNODE*next;

}NODE;

NODE*Creat(intn);

voidprint(NODE*head);

NODE*AddPolyn(NODE*head1,NODE*head2);

NODE*Delfirst(NODE*head,NODE*q);

voidInsertBefore(NODE*p1,NODE*p2);

intcompare(inta,intb);

main()

{

NODE*head1,*head2,*head3;

intn1,n2;

printf("

请输入你需要的多项数的数目n1:

"

);

scanf("

%d"

&

n1);

head1=Creat(n1);

第一个多项式的显示:

\n"

print(head1);

\n请输入你需要的多项数的数目n2:

n2);

head2=Creat(n2);

\n第二个多项式的显示:

print(head2);

head3=AddPolyn(head1,head2);

\n合并后的多项式的显示:

print(head3);

\n"

}

/*创建链表*/

NODE*Creat(intn)

NODE*current,*previous,*head;

inti;

head=(NODE*)malloc(sizeof(NODE));

/*创建头结点*/

previous=head;

for(i=0;

i<

n;

i++)

{

current=(NODE*)malloc(sizeof(NODE));

请输入系数和指数:

%f%d"

current->

coef,&

expn);

previous->

next=current;

previous=current;

}

next=NULL;

returnhead;

/*一元多项式的想加,总体考虑,可分qa的指数比qb小,或等于pb(如果系数相加等于0和不等于0),或大于pb

里面由InsertBefore和Delfirst两个小模块组成一部分*/

NODE*AddPolyn(NODE*head1,NODE*head2)

NODE*ha,*hb,*qa,*qb;

inta,b;

floatsum;

ha=head1;

/*ha和hb指向头结点*/

hb=head2;

qa=ha->

next;

/*qa和qb指向头结点的下一个结点*/

qb=hb->

while(qa&

&

qb)/*qa和qb均非空*/

a=qa->

expn;

b=qb->

switch(compare(a,b)){

case-1:

/*qa->

expn<

qb->

expn*/

ha=qa;

qa=qa->

break;

case0:

sum=qa->

coef+qb->

coef;

/*系数的和*/

if(sum!

=0.0){/*如果不是0.0*/

qa->

coef=sum;

/*改变系数*/

}else{

free(Delfirst(ha,qa));

}

free(Delfirst(hb,qb));

/*qb释放后要重新赋值*/

case1:

/*如果qa->

expn>

qb->

expn*/

Delfirst(hb,qb);

InsertBefore(ha,qb);

/*把qb插入到ha下一个结点之前*/

ha=ha->

if(qb)

ha->

next=qb;

/*插入剩余的pb*/

free(head2);

returnhead1;

/*比较*/

intcompare(inta,intb)

if(a<

b)

return-1;

elseif(a>

return1;

else

return0;

/*删除结点q*/

NODE*Delfirst(NODE*p1,NODE*q)

p1->

next=q->

next;

return(q);

/*插入结点,引入结点p,可以让p插入到p2和p1之间*/

voidInsertBefore(NODE*p1,NODE*p2)

NODE*p;

p=p1->

p1->

next=p2;

p2->

next=p;

/*打印,为了美观程序分开打印*/

voidprint(NODE*head)

NODE*current;

current=head->

while(current->

next!

=NULL)

%0.f*x^%d+"

current->

coef,current->

current=current->

%0.f*x^%d"

六调试分析

如图第八行,如果直接一次性输完两项的次数和项数,还是会显示“请输入系数和指数”

纠正办法:

输入时输完一项的系数和指数,按回车后继续输入。

七测试结果

输入一个二次三项式X^2+3X^+1,一个三次四项式2X^3+4X^2+X+1

输出如图:

八心得体会

首先,我的C++学的不是很好,因此做这样一个课程设计感觉有点吃力,还好我不断的看书,翻阅资料,询问同学,上网搜索,总算像模像样地把这个程序编的能运行了。

功夫不负有心人。

其次,这次编程是我更多地理解掌握了线性链表的逻辑机构和物理特性。

对大一时学过的知识有了很好的巩固。

困难还是很多的,比如初次运行的时候,好几十个错误,当时真的感到非常崩溃。

幸亏我没有放弃,才最终完成。

长舒一口气。

最后,通过这次编程,不仅仅考察了我对知识的掌握,更重要的是锻炼了我的思维能力和耐心,在最困难的时候没有放弃,今天才能如此舒心。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 法律文书 > 起诉状

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1