数据结构课后习题答案详解(C语言版-严蔚敏).doc

上传人:xin****828 文档编号:6564725 上传时间:2020-02-29 格式:DOC 页数:56 大小:714KB
返回 下载 相关 举报
数据结构课后习题答案详解(C语言版-严蔚敏).doc_第1页
第1页 / 共56页
数据结构课后习题答案详解(C语言版-严蔚敏).doc_第2页
第2页 / 共56页
数据结构课后习题答案详解(C语言版-严蔚敏).doc_第3页
第3页 / 共56页
点击查看更多>>
资源描述
数据结构习题集答案(C语言版严蔚敏)第2章 线性表2.1 描述以下三个概念的区别:头指针,头结点,首元结点(第一个元素结点)。解:头指针是指向链表中第一个结点的指针。首元结点是指链表中存储第一个数据元素的结点。头结点是在首元结点之前附设的一个结点,该结点不存储数据元素,其指针域指向首元结点,其作用主要是为了方便对链表的操作。它可以对空表、非空表以及首元结点的操作进行统一处理。2.2 填空题。解:(1) 在顺序表中插入或删除一个元素,需要平均移动表中一半元素,具体移动的元素个数与元素在表中的位置有关。 (2) 顺序表中逻辑上相邻的元素的物理位置必定紧邻。单链表中逻辑上相邻的元素的物理位置不一定紧邻。 (3) 在单链表中,除了首元结点外,任一结点的存储位置由其前驱结点的链域的值指示。 (4) 在单链表中设置头结点的作用是插入和删除首元结点时不用进行特殊处理。2.3 在什么情况下用顺序表比链表好?解:当线性表的数据元素在物理位置上是连续存储的时候,用顺序表比用链表好,其特点是可以进行随机存取。2.4 对以下单链表分别执行下列各程序段,并画出结果示意图。解: 2.5 画出执行下列各行语句后各指针及链表的示意图。L=(LinkList)malloc(sizeof(LNode);P=L;for(i=1;inext=(LinkList)malloc(sizeof(LNode);P=P-next;P-data=i*2-1;P-next=NULL;for(i=4;i=1;i-) Ins_LinkList(L,i+1,i*2);for(i=1;inext=S;(2) P-next=P-next-next;(3) P-next=S-next;(4) S-next=P-next;(5) S-next=L;(6) S-next=NULL;(7) Q=P;(8) while(P-next!=Q) P=P-next;(9) while(P-next!=NULL) P=P-next;(10) P=Q;(11) P=L;(12) L=S;(13) L=P;解:a. (4) (1)b. (7) (11) (8) (4) (1)c. (5) (12)d. (9) (1) (6)2.7 已知L是带表头结点的非空单链表,且P结点既不是首元结点,也不是尾元结点,试从下列提供的答案中选择合适的语句序列。 a. 删除P结点的直接后继结点的语句序列是_。 b. 删除P结点的直接前驱结点的语句序列是_。 c. 删除P结点的语句序列是_。 d. 删除首元结点的语句序列是_。e. 删除尾元结点的语句序列是_。(1) P=P-next;(2) P-next=P;(3) P-next=P-next-next;(4) P=P-next-next;(5) while(P!=NULL) P=P-next;(6) while(Q-next!=NULL) P=Q; Q=Q-next; (7) while(P-next!=Q) P=P-next;(8) while(P-next-next!=Q) P=P-next;(9) while(P-next-next!=NULL) P=P-next;(10) Q=P;(11) Q=P-next;(12) P=L;(13) L=L-next;(14) free(Q);解:a. (11) (3) (14)b. (10) (12) (8) (3) (14)c. (10) (12) (7) (3) (14)d. (12) (11) (3) (14)e. (9) (11) (3) (14)2.8 已知P结点是某双向链表的中间结点,试从下列提供的答案中选择合适的语句序列。a. 在P结点后插入S结点的语句序列是_。b. 在P结点前插入S结点的语句序列是_。c. 删除P结点的直接后继结点的语句序列是_。d. 删除P结点的直接前驱结点的语句序列是_。e. 删除P结点的语句序列是_。(1) P-next=P-next-next;(2) P-priou=P-priou-priou;(3) P-next=S;(4) P-priou=S;(5) S-next=P;(6) S-priou=P;(7) S-next=P-next;(8) S-priou=P-priou;(9) P-priou-next=P-next;(10) P-priou-next=P;(11) P-next-priou=P;(12) P-next-priou=S;(13) P-priou-next=S;(14) P-next-priou=P-priou;(15) Q=P-next;(16) Q=P-priou;(17) free(P);(18) free(Q);解:a. (7) (3) (6) (12)b. (8) (4) (5) (13)c. (15) (1) (11) (18)d. (16) (2) (10) (18)e. (14) (9) (17)2.9 简述以下算法的功能。(1) Status A(LinkedList L) /L是无表头结点的单链表if(L & L-next) Q=L;L=L-next;P=L;while(P-next) P=P-next;P-next=Q;Q-next=NULL;return OK;(2) void BB(LNode *s, LNode *q) p=s;while(p-next!=q) p=p-next;p-next =s;void AA(LNode *pa, LNode *pb) /pa和pb分别指向单循环链表中的两个结点BB(pa,pb);BB(pb,pa);解:(1) 如果L的长度不小于2,将L的首元结点变成尾元结点。 (2) 将单循环链表拆成两个单循环链表。2.10 指出以下算法中的错误和低效之处,并将它改写为一个既正确又高效的算法。Status DeleteK(SqList &a,int i,int k)/本过程从顺序存储结构的线性表a中删除第i个元素起的k个元素if(i1|ka.length) return INFEASIBLE;/参数不合法else for(count=1;count=i+1;j-) a.elemj-i=a.elemj;a.length-;return OK;解:Status DeleteK(SqList &a,int i,int k)/从顺序存储结构的线性表a中删除第i个元素起的k个元素/注意i的编号从0开始int j;if(ia.length-1|ka.length-i) return INFEASIBLE;for(j=0;j0,xB.length?A.length:B.length;for(i=0;iB.elemi) j=1;if(A.elemik) j=1;if(B.lengthk) j=-1;if(A.length=B.length) j=0;return j;2.13 试写一算法在带头结点的单链表结构上实现线性表操作Locate(L,x);解:int LocateElem_L(LinkList &L,ElemType x)int i=0;LinkList p=L;while(p&p-data!=x)p=p-next;i+;if(!p) return 0;else return i;2.14 试写一算法在带头结点的单链表结构上实现线性表操作Length(L)。解:/返回单链表的长度int ListLength_L(LinkList &L)int i=0;LinkList p=L;if(p) p=p-next;while(p)p=p-next;i+;return i;2.15 已知指针ha和hb分别指向两个单链表的头结点,并且已知两个链表的长度分别为m和n。试写一算法将这两个链表连接在一起,假设指针hc指向连接后的链表的头结点,并要求算法以尽可能短的时间完成连接运算。请分析你的算法的时间复杂度。解:void MergeList_L(LinkList &ha,LinkList &hb,LinkList &hc)LinkList pa,pb;pa=ha;pb=hb;while(pa-next&pb-next)pa=pa-next;pb=pb-next;if(!pa-next)hc=hb;while(pb-next) pb=pb-next;pb-next=ha-next;elsehc=ha;while(pa-next) pa=pa-next;pa-next=hb-next;2.16 已知指针la和lb分别指向两个无头结点单链表中的首元结点。下列算法是从表la中删除自第i个元素起共len个元素后,将它们插入到表lb中第i个元素之前。试问此算法是否正确?若有错,请改正之。Status DeleteAndInsertSub(LinkedList la,LinkedList lb,int i,int j,int len)if(i0|j0|len0) return INFEASIBLE;p=la;k=1;while(knext;k+;q=p;while(knext;k+;s=lb; k=1;while(knext;k+;s-next=p; q-next=s-next;return OK;解:Status DeleteAndInsertSub(LinkList &la,LinkList &lb,int i,int j,int len)LinkList p,q,s,prev=NULL;int k=1;if(i0|j0|len0) return INFEASIBLE;/ 在la表中查找第i个结点p=la;while(p&knext;k+;if(!p)return INFEASIBLE;/ 在la表中查找第i+len-1个结点q=p;k=1;while(q&knext;k+;if(!q)return INFEASIBLE;/ 完成删除,注意,i=1的情况需要特殊处理if(!prev) la=q-next;else prev-next=q-next;/ 将从la中删除的结点插入到lb中if(j=1)q-next=lb;lb=p;elses=lb;k=1;while(s&knext;k+;if(!s)return INFEASIBLE;q-next=s-next;s-next=p; /完成插入return OK;2.17 试写一算法,在无头结点的动态单链表上实现线性表操作Insert(L,i,b),并和在带头结点的动态单链表上实现相同操作的算法进行比较。2.18试写一算法,实现线性表操作Delete(L,i),并和在带头结点的动态单链表上实现相同操作的算法进行比较。2.19 已知线性表中的元素以值递增有序排列,并以单链表作存储结构。试写一高效的算法,删除表中所有值大于mink且小于maxk的元素(若表中存在这样的元素),同时释放被删结点空间,并分析你的算法的时间复杂度(注意,mink和maxk是给定的两个参变量,它们的值可以和表中的元素相同,也可以不同)。解:Status ListDelete_L(LinkList &L,ElemType mink,ElemType maxk)LinkList p,q,prev=NULL;if(minkmaxk)return ERROR;p=L;prev=p;p=p-next;while(p&p-datadatanext;elseprev-next=p-next;q=p;p=p-next;free(q);return OK;2.20 同2.19题条件,试写一高效的算法,删除表中所有值相同的多余元素(使得操作后的线性表中所有元素的值均不相同),同时释放被删结点空间,并分析你的算法的时间复杂度。解:void ListDelete_LSameNode(LinkList &L)LinkList p,q,prev;p=L;prev=p;p=p-next;while(p)prev=p;p=p-next;if(p&p-data=prev-data)prev-next=p-next;q=p;p=p-next;free(q);2.21 试写一算法,实现顺序表的就地逆置,即利用原表的存储空间将线性表逆置为。解:/ 顺序表的逆置Status ListOppose_Sq(SqList &L)int i;ElemType x;for(i=0;inext;L-next=NULL;while(p)q=p;p=p-next;q-next=L-next;L-next=q;return OK;2.23 设线性表,试写一个按下列规则合并A,B为线性表C的算法,即使得当时;当时。线性表A,B和C均以单链表作存储结构,且C表利用A表和B表中的结点空间构成。注意:单链表的长度值m和n均未显式存储。解:/ 将合并后的结果放在C表中,并删除B表Status ListMerge_L(LinkList &A,LinkList &B,LinkList &C)LinkList pa,pb,qa,qb;pa=A-next;pb=B-next;C=A;while(pa&pb)qa=pa;qb=pb;pa=pa-next;pb=pb-next;qb-next=qa-next;qa-next=qb;if(!pa)qb-next=pb;pb=B;free(pb);return OK;2.24 假设有两个按元素值递增有序排列的线性表A和B,均以单链表作存储结构,请编写算法将A表和B表归并成一个按元素值递减有序(即非递增有序,允许表中含有值相同的元素)排列的线性表C,并要求利用原表(即A表和B表)的结点空间构造C表。解:/ 将合并逆置后的结果放在C表中,并删除B表Status ListMergeOppose_L(LinkList &A,LinkList &B,LinkList &C)LinkList pa,pb,qa,qb;pa=A;pb=B;qa=pa;/ 保存pa的前驱指针qb=pb;/ 保存pb的前驱指针pa=pa-next;pb=pb-next;A-next=NULL;C=A;while(pa&pb)if(pa-datadata)qa=pa;pa=pa-next;qa-next=A-next;/将当前最小结点插入A表表头A-next=qa;elseqb=pb;pb=pb-next;qb-next=A-next;/将当前最小结点插入A表表头A-next=qb;while(pa)qa=pa;pa=pa-next;qa-next=A-next;A-next=qa;while(pb)qb=pb;pb=pb-next;qb-next=A-next;A-next=qb;pb=B;free(pb);return OK;2.25 假设以两个元素依值递增有序排列的线性表A和B分别表示两个集合(即同一表中的元素值各不相同),现要求另辟空间构成一个线性表C,其元素为A和B中元素的交集,且表C中的元素有依值递增有序排列。试对顺序表编写求C的算法。解:/ 将A、B求交后的结果放在C表中Status ListCross_Sq(SqList &A,SqList &B,SqList &C)int i=0,j=0,k=0;while(iA.length & jB.length)if(A.elemiB.elemj)j+;elseListInsert_Sq(C,k,A.elemi);i+;k+;return OK;2.26 要求同2.25题。试对单链表编写求C的算法。解:/ 将A、B求交后的结果放在C表中,并删除B表Status ListCross_L(LinkList &A,LinkList &B,LinkList &C)LinkList pa,pb,qa,qb,pt;pa=A;pb=B;qa=pa;/ 保存pa的前驱指针qb=pb;/ 保存pb的前驱指针pa=pa-next;pb=pb-next;C=A;while(pa&pb)if(pa-datadata)pt=pa;pa=pa-next;qa-next=pa;free(pt);elseif(pa-datapb-data)pt=pb;pb=pb-next;qb-next=pb;free(pt);elseqa=pa;pa=pa-next;while(pa)pt=pa;pa=pa-next;qa-next=pa;free(pt);while(pb)pt=pb;pb=pb-next;qb-next=pb;free(pt);pb=B;free(pb);return OK;2.27 对2.25题的条件作以下两点修改,对顺序表重新编写求得表C的算法。(1) 假设在同一表(A或B)中可能存在值相同的元素,但要求新生成的表C中的元素值各不相同;(2) 利用A表空间存放表C。解:(1)/ A、B求交,然后删除相同元素,将结果放在C表中Status ListCrossDelSame_Sq(SqList &A,SqList &B,SqList &C)int i=0,j=0,k=0;while(iA.length & jB.length)if(A.elemiB.elemj)j+;elseif(C.length=0)ListInsert_Sq(C,k,A.elemi);k+;elseif(C.elemC.length-1!=A.elemi)ListInsert_Sq(C,k,A.elemi);k+;i+;return OK;(2)/ A、B求交,然后删除相同元素,将结果放在A表中Status ListCrossDelSame_Sq(SqList &A,SqList &B)int i=0,j=0,k=0;while(iA.length & jB.length)if(A.elemiB.elemj)j+;elseif(k=0)A.elemk=A.elemi;k+;elseif(A.elemk!=A.elemi)A.elemk=A.elemi;k+;i+;A.length=k;return OK;2.28 对2.25题的条件作以下两点修改,对单链表重新编写求得表C的算法。(1) 假设在同一表(A或B)中可能存在值相同的元素,但要求新生成的表C中的元素值各不相同;(2) 利用原表(A表或B表)中的结点构成表C,并释放A表中的无用结点空间。解:(1)/ A、B求交,结果放在C表中,并删除相同元素Status ListCrossDelSame_L(LinkList &A,LinkList &B,LinkList &C)LinkList pa,pb,qa,qb,pt;pa=A;pb=B;qa=pa;/ 保存pa的前驱指针qb=pb;/ 保存pb的前驱指针pa=pa-next;pb=pb-next;C=A;while(pa&pb)if(pa-datadata)pt=pa;pa=pa-next;qa-next=pa;free(pt);elseif(pa-datapb-data)pt=pb;pb=pb-next;qb-next=pb;free(pt);elseif(pa-data=qa-data)pt=pa;pa=pa-next;qa-next=pa;free(pt);elseqa=pa;pa=pa-next;while(pa)pt=pa;pa=pa-next;qa-next=pa;free(pt);while(pb)pt=pb;pb=pb-next;qb-next=pb;free(pt);pb=B;free(pb);return OK;(2)/ A、B求交,结果放在A表中,并删除相同元素Status ListCrossDelSame_L(LinkList &A,LinkList &B)LinkList pa,pb,qa,qb,pt;pa=A;pb=B;qa=pa;/ 保存pa的前驱指针qb=pb;/ 保存pb的前驱指针pa=pa-next;pb=pb-next;while(pa&pb)if(pa-datadata)pt=pa;pa=pa-next;qa-next=pa;free(pt);elseif(pa-datapb-data)pt=pb;pb=pb-next;qb-next=pb;free(pt);elseif(pa-data=qa-data)pt=pa;pa=pa-next;qa-next=pa;free(pt);elseqa=pa;pa=pa-next;while(pa)pt=pa;pa=pa-next;qa-next=pa;free(pt);while(pb)pt=pb;pb=pb-next;qb-next=pb;free(pt);pb=B;free(pb);return OK;2.29 已知A,B和C为三个递增有序的线性表,现要求对A表作如下操作:删去那些既在B表中出现又在C表中出现的元素。试对顺序表编写实现上述操作的算法,并分析你的算法的时间复杂度(注意:题中没有特别指明同一表中的元素值各不相同)。解:/ 在A中删除既在B中出现又在C中出现的元素,结果放在D中Status ListUnion_Sq(SqList &D,SqList &A,SqList &B,SqList &C)SqList Temp;InitList_Sq(Temp);ListCross_L(B,C,Temp);ListMinus_L(A,Temp,D);2.30 要求同2.29题。试对单链表编写算法,请释放A表中的无用结点空间。解:/ 在A中删除既在B中出现又在C中出现的元素,并释放B、CStatus ListUnion_L(LinkList &A,LinkList &B,LinkList &C)ListCross_L(B,C);ListMinus_L(A,B);/ 求集合A-B,结果放在A表中,并删除B表Status ListMinus_L(LinkList &A,LinkList &B)LinkList pa,pb,qa,qb,pt;pa=A;pb=B;qa=pa;/ 保存pa的前驱指针qb=pb;/ 保存pb的前驱指针pa=pa-next;pb=pb-next;while(pa&pb)if(pb-datadata)pt=pb;pb=pb-next;qb-next=pb;free(pt);elseif(pb-datapa-data)qa=pa;pa=pa-next;elsept=pa;pa=pa-next;qa-next=pa;free(pt);while(pb)pt=pb;pb=pb-next;qb-next=pb;free(pt);pb=B;free(pb);return OK;2.31 假设某个单向循环链表的长度大于1,且表中既无头结点也无头指针。已知s为指向链表中某个结点的指针,试编写算法在链表中删除指针s所指结点的前驱结点。解:/ 在单循环链表S中删除S的前驱结点Status ListDelete_CL(LinkList &S)LinkList p,q;if(S=S-next)return ERROR;q=S;p=S-next;while(p-next!=S)q=p;p=p-next;q-next=p-next;free(p);return OK;2.32 已知有一个单向循环链表,其每个结点中含三个域:pre,data和next,其中data为数据域,next为指向后继结点的指针域,pre也为指针域,但它的值为空,试编写算法将此单向循环链表改为双向循环链表,即使pre成为指向前驱结点的指针域。解:/ 建立一个空的循环链表Status InitList_DL(DuLinkList &L)L=(DuLinkList)malloc(sizeof(DuLNode);if(!L) exit(OVERFLOW);L-pre=NULL;L-next=L;return OK;/ 向循环链表中插入一个结点Status ListInsert_DL(DuLinkList &L,ElemType e)DuLinkList p;p=(DuLinkList)malloc(sizeof(DuLNode);if(!p) return ERROR;p-data=e;p-next=L-next;L-next=p;return OK;/ 将单循环链表改成双向链表Status ListCirToDu(DuLinkList &L)DuLinkList p,q;q=L;p=L-next;while(p!=L)p-pre=q;q=p;p=p-next;if(p=L) p-pre=q;return OK;2.33 已知由一个线性链表表示的线性表中含有三类字符的数据元素(如:字母字符、数字字符和其他字符),试编写算法将该线性表分割为三个循环链表,其中每个循环链表表示的线性表中均只含一类字符。解:/ 将单链表L划分成3个单循环链表Status ListDivideInto3CL(LinkList &L,LinkList &s1,LinkList &s2,LinkList &s3)LinkList p,q,pt1,pt2,pt3;p=L-next;pt1=s1;pt2=s2;pt3=s3;while(p)if(p-data=0 & p-datanext;q-next=pt1-next;pt1-next=q;pt1=pt1-next;elseif(p-data=A & p-datadata=a & p-datanext;q-next=pt2-next;pt2-next=q;pt2=pt2-next;elseq=p;p=p-next;q-next=pt3-next;pt3-next=q;pt3=pt3-next;q=L;free(q);return OK;在2.34至2.36题中,“异或指针双向链表”类型XorLinkedList和指针异或函数XorP定义为:typedefstructXorNode char data;structXorNode *LRPtr; XorNode, *XorPointer;typedestruct /无头结点的异或指针双向链表XorPointerLeft, Right;/分别指向链表的左侧和右端 XorLinkedList;XorPointer XorP(XorPointer p, XorPointer q);/ 指针异或函数XorP返回指针p和q的异或值2.34 假设在算法描述语言中引入指针的二元运算“异或”,若a和b为指针,则ab的运算结果仍为原指针类型,且a(ab)=(aa)b=b(ab)b=a(bb)=a则可利用一个指针域来实现双向链表L。链表L中的每个结点只含两个域:data域和LRPtr域,其中LRPtr域存放该结点的左邻与右邻结点指针(不存在时为NULL)的异或。若设指针L.Left指向链表中的最左结点,L.Right指向链表中的最右结点,则可实现从左向右或从右向左遍历此双向链表的操作。试写一算法按任一方向依次输出链表中各元素的值。解:Status TraversingLinkList(XorLinkedList &L,char d)XorPointer p,left,right;if(d=l|d=L)p=L.Left;left=NULL;while(p!=NULL)VisitingData(p-data);left=p;p=XorP(left,p-LRPtr);elseif(d=r|d=R)p=L.Right;right=NULL;while(p!=NULL)VisitingData(p-data);right=p;p=XorP(p-LRPtr,right);else return ERROR;return OK;2.35 采用2.34题所述的存储结构,写出在第i个结点之前插入一个结点的算法。2.36 采用2.34题所述的存储结构,写出删除第i个结点的算法。2.37 设以带头结点的双向循环链表表示的线性表。试写一时间复杂度O(n)的算法,将L改造为。解:/ 将双向链表L=(a1,a2,.,an)改造为(a1,a3,.,an,.,a2)Status ListChange_DuL(DuLinkList &L)int i;DuLinkList p,q,r;p=L-next;r=L-pre;i=1;while(p!=r)if(i%2=0)q=p;p=p-next;/ 删除结点q-pre-next=q-next;q-next-pre=q-pre;/ 插入到头结点的左面q-pre=r-next-pre;r-next-pre=q;q-next=r-next;r-next=q;else p=p-next;i+;return OK;2.38 设有一个双向循环链表,每个结点中除有pre,data和next三个域外,还增设了一个访问频度域freq。在链表被起用之前,频度域freq的值均初始化为零,而每当对链表进行一次Locate(L,x)的操作后,被访问的结点(即元素值等于x的结点)中的频度域freq的值便增1,同时调整链表中结点之间的次序,使其按访问频度非递增的次序顺序排列,以便始终保持被频繁访问的结点总是靠近表头结点。试编写符合上述要求的Locate操作的算法。解:DuLinkList ListLocate_DuL(DuLinkList &L,ElemType e)DuLinkList p,q;p=L-next;while(p!=L & p-data!=e)p=p-next;if(p=L) return NULL;elsep-freq+;/ 删除结点p-pre-next=p-next;p-next-pre=p-pre;/ 插入到合适的位置q=L-next;while(q!=L & q-freqp-freq) q=q-next;if(q=L)p-next=q-next;q-next=p;p-pre=q-pre;q-pre=p;else/ 在q之前插入p-next=q-pre-next;q-pre-next=p;p-pre=q-pre;q-pre=p;return p;在2.39至2.40题中,稀疏多项式采用的顺序存储结构SqPoly定义为typedefstruct intcoef;int exp; PolyTerm;typedef struct /多项式的顺序存储结构PolyTerm *data;int last; SqPoly;2.39 已知稀疏多项式,其中,。试采用存储量同多项式项数m成正比的顺序存储结构,编写求的算法(为给定值),并分析你的算法的时间复杂度。解:typedef structint coef;int exp; PolyTerm;typedef structPolyTerm *data;int last; SqPoly;/ 建立一个多项式Status PolyInit(SqPoly &L)int i;PolyTerm *p;coutL.last;L.data=(PolyTerm *)malloc(L.last*sizeof(PolyTerm);if(!L.data) return ERROR;p=L.data;for(i=0;iL.last;i+)coutp-coef;coutp-exp;p+;return OK; / 求多项式的值double PolySum(SqPoly &L,double x0)double Pn,x;int i,j;PolyTerm *p;p=L.data;for(i=0,Pn=0;iL.last;i+,p+)for(j=0,x=1;jexp;j+) x=x*x0;Pn=Pn+p-coef*x;return Pn;2.40 采用2.39题给定的条件和存储结构,编写求的算法,将结果多项式存放在新辟的空间中,并分析你的算法的时间复杂度。解:/ 求两多项式的差Status PolyMinus(SqPoly &L,SqPoly &L1,SqPoly &L2)PolyTerm *p,*p1,*p2;p=L.data;p1=L1.data;p2=L2.data;int i=0,j=0,k=0;while(iL1.last&jexpexp)p-coef=p1-coef;p-exp=p1-exp;p+;k+;p1+;i+;elseif(p1-expp2-exp)p-coef=-p2-coef;p-exp=p2-exp;p+;k+;p2+;j+;elseif(p1-coef!=p2-coef)p-coef=(p1-coef)-(p2-coef);p-exp=p1-exp;p+;k+;p1+;p2+;i+;j+;if(iL1.last)while(icoef=p1-coef;p-exp=p1-exp;p+;k+;p1+;i+;if(jL2.last)while(jcoef=-p2-coef;p-exp=p2-exp;p+;k+;p2+;j+;L.last=k;return OK;在2.41至2.42题中,稀疏多项式采用的循环链表存储结构LinkedPoly定义为typedef struct PolyNode PolyTerm data;struct PolyNode *next; PolyNode, *PolyLink;typedef PolyLink LinkedPoly;2.41 试以循环链表作稀疏多项式的存储结构,编写求其导函数的方法,要求利用原多项式中的结点空间存放其导函数多项式,同时释放所有无用结点。解:Status PolyDifferential
展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 图纸专区 > 小学资料


copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!