欢迎来到淘文阁 - 分享文档赚钱的网站! | 帮助中心 好文档才是您的得力助手!
淘文阁 - 分享文档赚钱的网站
全部分类
  • 研究报告>
  • 管理文献>
  • 标准材料>
  • 技术资料>
  • 教育专区>
  • 应用文书>
  • 生活休闲>
  • 考试试题>
  • pptx模板>
  • 工商注册>
  • 期刊短文>
  • 图片设计>
  • ImageVerifierCode 换一换

    数据结构习题集答C语言版严蔚敏).docx

    • 资源ID:68390284       资源大小:359KB        全文页数:113页
    • 资源格式: DOCX        下载积分:12金币
    快捷下载 游客一键下载
    会员登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录   QQ登录  
    二维码
    微信扫一扫登录
    下载资源需要12金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    数据结构习题集答C语言版严蔚敏).docx

    第1章绪论1.1 简述下列术语:数据,数据元素、数据对象、数据结构、存储结构、数据类型和抽象数据类型。解:数据是对客观事物的符号表示。在计算机科学中是指所有能输入到计算机中并被计算机程序处理的符 号的总称。数据元素是数据的基本单位,在计算机程序中通常作为一个整体进行考虑和处理。数据对象是性质相同的数据元素的集合,是数据的一个子集。数据结构是相互之间存在-种或多种特定关系的数据元素的集合。存储结构是数据结构在计算机中的表示。数据类型是一个值的集合和定义在这个值集I:的一组操作的总称。抽象数据类型是指一个数学模型以及定义在该模型上的一组操作。是对一般数据类型的扩展。1.2 试描述数据结构和抽象数据类型的概念与程序设计语言中数据类型概念的区别.解:抽象数据类型包含一般数据类型的概念,但含义比一般数据类型更广、更抽象。一般数据类型由 具体语言系统内部定义,宜接提供给编程者定义用户数据,因此称它们为预定义数据类型。抽象数据类型 通常由编程者定义,包括定义它所使用的数据和在这些数据上所进行的操作.在定义抽象数据类型中的数 据部分和操作部分时,要求只定义到数据的逻辑结构和操作说明,不考虑数据的存储结构和操作的具体实 现,这样抽象层次更高,更能为其他用户提供良好的使用接口.1.3 设有数据结构(D,R),其中D = dl,d2,d3,d4, R = r, r = (dl,d2Md2,d3Md3,d4)试按图论中图的画法惯例画出其逻辑结构图。1.4 试仿照三元组的抽象数据类型分别写出抽象数据类型复数和有理数的定义(有理数是其分子、分母均 为自然数且分母不为零的分数).解:ADT Complex数据对象:D=r, i|r, i为实数数据关系:R=<r,i»基本操作:InitComplex(&C, re, ira)操作结果:构造一个复数C,其实部和虚部分别为re和imDestroyCmoplex(&C)操作结果:销毁复数CGet (C, k, &e)操作结果:用e返可复数C的第k元的值Put (&C, k, e)操作结果:改变复数C的第k元的值为eIsAscending(C)操作结果:如果复数C的两个元素按升序排列,则返回1,否则返回0IsDescending(C)操作结果:如果复数C的两个元素按降序排列,则返回1,否则返回0 Max(C, &e)操作结果:用e返回复数C的两个元素中值较大的个Min(C, &e)操作结果:用e返回复数C的两个元素中值较小的个ADT ComplexADT RationalNumber数据对象:D;s,m|s,m为自然数,且m不为0数据关系:R=<s, m»基本操作:Ini tRat ionalNumber(&R, s, m)操作结果:构造一个有理数R,其分子和分母分别为s和mDestroyRationalNumber(&R)操作结果:销毁有理数RGet (R, k, &e)操作结果:用e返回有理数R的第k元的值Put (&R, k, e)操作结果:改变有理数R的第k元的值为eIsAscending(R)操作结果:若有理数R的两个元素按升序排列,则返回1,否则返回0 IsDescending(R)操作结果:若有理数R的两个元素按降序排列,则返回1,否则返回0 Max (R, &e)操作结果:用e返回有理数R的两个元素中值较大的一个Min(R, &e)操作结果:用e返回有理数R的两个元素中值较小的一个ADT RationalNumber1.5 试画出与下列程序段等价的框图。(1) product=l; i=l;while(i<=n)product *= i;i+; i=0;do i+; while(i!=n) && (ai !=x);1.1 switch case x<y: z=y-x; break;case x=y: z=abs(x*y); break;default: z=(x-y)/abs(x)*abs(y);1.6 在程序设计中,常用下列三种不同的出错处理方式:(1)用exit语句终止执行并报告错误;(2)以函数的返回值区别正确返回或错误返回;(3)设置一个整型变量的函数参数以区别正确返回或某种错误返回.试讨论这三种方法各自的优缺点.解:(Dexit常用于异常错误处理,它可以强行中断程序的执行,返回操作系统。(2)以函数的返回值判断正确与否常用于子程序的测试,便于实现程序的局部控制。(3)用整型函数进行错误处理的优点是可以给出错误类型,便于迅速确定错误。1.7 在程序设计中,可采用下列三种方法实现输出和输入:(1)通过scanf和printf语句;(2)通过函数的参数显式传递;(3)通过全局变量隐式传递.试讨论这三种方法的优缺点。解:(D用scanf和printf直接进行输入输出的好处是形象、直观,但缺点是需要对其进行格式控制, 较为烦琐,如果出现错误,则会引起整个系统的崩溃。(2)通过函数的参数传递进行输入输出,便于实现信息的隐蔽,减少出错的可能。(3)通过全局变鼠的隐式传递进行输入输出最为方便,只需修改变最的值即可,但过多的仝局变最使程 序的维护较为困难。1.8 设n为正整数。试确定下列各程序段中前置以记号的语句的频度,(1) i=l; k=0;while(i<=n-l)9 k += 10*i;i+:(2) i=l; k=0;do 0 k += 10*i;i+; while(i<=n-l);(3) i=l; k=0;while (i<=n-l) i+;0 k += 10*i;(4) k=0;for(i=l; i<=n; i+) for(j=i: j<=n: j+)9 k+;)(5) for(i=l; i<=n; i+) for(j=l; j<=i: j+) for(k=l; k<=j; k+)0 x += delta;(6) i=l: j=0;while(i+j<=n) if(i>j) j+:else i+;(7) x=n; y=0;/ n是不小于1的常数while(x>=(y+1)*(y+l) y+;(8) x=91; y=100;while(y>0) if(x>100) x -= 10; y-; else x+;解:(1) n-ln-1n-1,、,、,、( + l)(4) n+(n-l) + (n-2)+. +1=25 i(i +1)(5) l+(l+2)+ (1+2+3)+. + (l+2+3+. +n):,i=i 2n(n +1)(2 + 1) + n(n +1) = - nn +1)(2 + 3)(6) n(7) _V«J向下取整(8) 11001.9假设n为2的乘蹇,并且n>2,试求下列算法的时间复杂度及变量count的值(以n的函数形式表示). int Time(int n) count = 0;x=2;while(x<n/2) x = 2; count+ ; return count;解:f?(log2 n)count= log, n 21.11 已知有实现同一功能的两个算法,其时间复杂度分别为。(2")和假设现实计算机可连续 运算的时间为1。7秒(100多天),又每秒可执行基本操作(根据这些操作来估算算法时间复杂度)1()5次。 试问在此条件下,这两个算法可解问题的规模(即n值的范围)各为多少?哪个算法更适宜?请说明理由.解:2" = 1012n=40n10 =1012n=16则对于同样的循环次数n,在这个规模下,第二种算法所花费的代价要大得多。故在这个规模下,第 一种算法更适宜.1.12 设有以下三个函数:/(n)=21M4+n2 +1000, g(n)= 15n4 +500n /(«) = 500/?15 + nlogm请判断以下断言正确与否:(1) f(n)是0(g(n)(2) 11(11)是0任(11)(3) 8(11)是0(11(11)(4) h(n)是 0(n*(5) h(n)是 O(nlogn)解:对错错(4)对错1.13 试设定若干n值,比较两函数 2和50 log2 的增长趋势,并确定n在什么范围内,函数/的值大于50 log 2 的值。解:的增长趋势快。但在门较小的时候,50log2的值较大。当 n438 时,n2 >50nlog2n1.14 判断下列各对函数/()和g(),当 f 8时,哪个函数增长更快?(1) /() = IO”? + ln(!+10" ), g()=2,+ + 7(2) /(n) = (ln(n!)+5)2, g(n) = 13n25(3) fn) = n2' + J4 +1, g(n) = (ln(n!)2 + n(4) f() = 2(")+(2")一, g() =(")+ '解:g(n)快(2)g(n)快(3)f(n)快(4) f(n)快1.15 试用数学归纳法证明:(1) =(+ 1)(2+ 1)/6(n > 0)(2) Z / =(-"一1)/(戈-1)(x 1, n > 0)i=0(3) 2,-1 =2" -1(/7>1)/=!(4) Z-1)=?(n > 1)i=l1.16 试写一算法,自大至小依次输出顺序读入的三个整数X, Y和Z的值解:int max3(int x, int y, int z) (if(x>y)i f(x>z) return x;else return z;elseif(y>z) return y;else return z;)1.17 已知k阶斐波那契序列的定义为/o =。,力=。fk-2 =。, fk- = 1 ;fn = fn- + fn-2 +, = %,k + 1,试编写求k阶斐波那契序列的第m项值的函数算法,k和m均以值调用的形式在函数参数表中出现。 解:k>0为阶数,n为数列的第n项int Fibonacci(int k, int n) if(k<l) exit(OVERFLOW);int *p, x;p=new intk+1;if(!p) exit(OVERFLOW);int i, j;for(i=0;i<k+l;i+) if(i<k-l) pi=0; else pi=l;for(i=k+l;i<n+l;i+)x=p0;for(j=0;j<k;j+) pj=pj+l;pk=2*pk-l-x; return pk;1.18 假设有A, B, C, D, E五个高等院校进行田径对抗赛,各院校的单项成绩均已存入计算机,并构成一 张表,表中每一行的形式为I项目名称I 性别 I 一名 I 成绩 I 得分一编写算法,处理上述表格,以统计各院校的男、女总分和团体总分,并输出.解:typedef enum A, B, C, D, E School Name;typedef enumFemale, Male) SexType;typedef struct(char event 3; 项目SexType sex;SchoolName school; int score; Component;typedef structint Mal eSum; 男团总分int FemaleSum; 女团总分 int TotalSum; 团体总分 Sum;Sum SumScore(SchoolName sn, Component a, int n) (Sum temp;temp. MaleSum=0;temp. FemaleSum=O;temp. TotalSum=0;int i;for(i=0;i<n;i+)if(ai. school=sn)if(ai. sex=二Male) temp. Ma1eSum+=ai. score;if(ai. sex=Female) temp. FemaleSum+=ai. score; )temp. TolaiSum=Iemp. MaleSum+temp. FemaleSum; return temp;)1.19 试编写算法,计算i!*2'的值并存入数组aO.arrsize-l的第i-1个分量中(i=l,2,n)。假设计算机中允许的整数最大值为maxint,则当n>arrsize或对某个4攵 (,使女!,2人> max int时,应按出错处理。注意选择你认为较好的出错处理方法。解:#include<iostream. h>#include<stdlib. h>define MAXINT 65535#define ArrSize 100 int fun(int i);int main()int i, k;int aArrSize;cout«*Enter k:"cin>>k;if(k>ArrSize-l) exit(0);for(i=0;i<=k;i+) if (i=0) ai=l; else if(2*i*ai-l>MAXINT) exit(0);else ai=2*i*ai-l;)for(i=0;i<=k;i+) if(ai>MAXINT) exit(0); else cout«ai<<*return 0;)1.20 试编写算法求一元多项式的值6, (x) = Z a/'的值?(Xo),并确定算法中每一语句的执行次数 1=0和整个算法的时间复杂度。注意选择你认为较好的输入和输出方法.本题的输入为4 (i = 0,1, ,),X。和,输出为P(x0).解:nc1ude< iostrearn. h>#include<stdlib. h>#def i ne N 10double polynomail(int a, int i,double x, int n);int main()(double x;int n, i;int aN;cout«”输入变量的值x:"cin>>x;cout<”输入多项式的阶次n:"cin>>n;if(n>N-l) exit(0);coul<<”输入多项式的系数a0-an:for (i=0; i<=n; i+) cin»ai;cout<<*The polynomail value is *<<polynomail (a, n, x, n)«endl;return 0;)double polynomail(int a,int i, double x,int n)(if (i>0) return an-i+polynomail (a, i-1, x, n)*x;else return an;)本算法的时间复杂度为。(n)。第2章线性表2.1 描述以下三个概念的区别:头指针,头结点,首元结点(第一个元素结点).解:头指针是指向链表中第一个结点的指针。首元结点是指链表中存储第一个数据元素的结点。头结 点是在首元结点之前附设的个结点,该结点不存储数据元素,其指针域指向首元结点,其作用主要是为 了方便时链表的操作。它可以对空表、非空表以及首元结点的操作进行统一处理。2.2 填空题.解:(D在顺序表中插入或删除一个元素,需要平均移动表中一表兀素,具体移动的元素个数与出 在表中的位置有大.(2)顺序表中逻辑I:相邻的元素的物理位置诞紧邻。雅链表中逻辑I:相邻的元素的物理位置不一定 紧邻。(3)在单链表中,除了首元结点外,任一结点的存储位置巾其旗蹒点点到扬%g指示。(4)在单雕表中设置头结点、的作网是插入和删除首元结点时不用进行特殊处理2. 3在什么情况下用顺序表比链表好?解:当线性表的数据元素在物理位置上是连续存储的时候,用顺序表比用链表好,其特点是可以进行 随机存取。2.4 对以下单链表分别执行下列各程序段,并画出结果示意图.6)2.5 画出执行下列各行语句后各指针及链表的示意图。L=(LinkList)malloc(sizeof(LNode); P=L;for(i=l;i<=4;i+)P->next=(LinkLi st)malloc(sizeof(LNode);P=P->next;P->data=i*2-l;P->next=NULL;for(i=4;i>=l;i) Ins_LinkList(L, i+1, i*2);for(i=l;i<=3;i+) Del_LinkList(L, i);解:L-p二2.6 已知L是无表头结点的单链表,且P结点既不是首元结点,也不是尾元结点,试从下列提供的答案中 选择合适的语句序列。a.在P结点后插入S结点的语句序列是.b.在P结点前插入s结点的语句序列是。c.在表首插入S结点的语句序列是。d.在表尾插入S结点的语句序列是。(1) P->next=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! =WJLL) 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) idiile(Q->next!ULL) 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结点的直接后继结点的语句序列是 Od.删除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) 1是无表头结点的单链表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 (i<l |k<0 | i+k>a. length) return INFEASIBLE;参数不合法 else (for(count=l;count<k;count+)删除第一个元素for(j=a. length;j>=i+l;j-) a. elemj-i=a. elemj;a. length一; return OK;)解:Status DeleteK(SqList &a, int i,int k) (从顺序存储结构的线性表a中删除第i个元素起的k个元素注意i的编号从。开始int j;if(i<0 |i>a. length_1 I|k<0 |k>a. length-i) return INFEASIBLE;for(j=0;j<=k;j+)a.elemj+i=a. elemj+i+k;a.length=a. length-k;return OK;j.2.11 设顺序表va中的数据元素递增有序。试写一算法,将x插入到顺序表的适当位置上,以保持该表的 有序性.解:Status InsertOrderList(SqList &va, ElemType x) (在非递减的顺序表va中插入元素x并使其仍成为顺序表的算法int i;if(va. length=va. listsize)return(OVERFLOW);for(i=va. length;i>0, x<va. elemi-l;i-)va. elemi=va. elemi-l;va. elemi=x;va. length+; return OK;)2.12 设A = (4,,a,“)和8 = (4,力,J均为顺序表,4'和B'分别为A和8中除去最大共同前缀后的子表.若A' = 8'=空表,则A = 8;若A'=空表,而8'*空表,或者两者均不为空表,且A' 的首元小于8'的首元,则否则A >8.试写一个比较A, 8大小的算法。解:Status CompareOrderList(SqList &A,SqList &B) (int i,k, j;k=A. length>B. length?A. length:B. length; for(i=0;i<k;i+)if (A. e 1 emi >B. e 1 emi) j=l;if (A. elemi<B. elemi) j=-l;if(A. length>k) j=l;if(B. length>k) j=-l;if(A. length=B. length) j=0;return j;)2.13 试写一算法在带头结点的单链表结构上实现线性表操作Located, x);解:int LocateE 1 em l.(LinkUst &L, ElemType x) (int i=0;LinkList p=L;wh i1e(p&&p->data!=x) p=p->next;i+;if(!p) return 0;else return i; )2.14 试写一算法在带头结点的单链表结构上实现线性表操作Length(L).解:返回单链表的长度int ListLength_I.(Linkl.ist &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.试写一算 法将这两个链表连接在一起,假设指针he指向连接后的链表的头结点,并要求算法以尽可能短的时间完成 连接运算。请分析你的算法的时间复杂度。解: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) he=hb;while(pb->next) pb=pb->next;pb->next=ha->next;elsehe二ha;while(pa->next) pa=pa->next;pa->next=hb->next;)2.16 已知指针la和lb分别指向两个无头结点单链表中的首元结点.下列算法是从表la中删除自第i个 元素起共len个元素后,将它们插入到表1b中第i个元素之前.试问此算法是否正确?若有错,请改正之。Status DeleteAndlnsertSub(LinkedList la, LinkedList lb,int i,int j, int len)(if(i<0 |j<0|len<0) return INFEASIBLE;p=la; k=l;while(k<i) p=p->next;k+; q 二P;while(k<=len) q=q->next;k+; s=lb; k=l;while(k<j) s=s->next;k+; s->next=p; q->next=s->next;return OK:)解:Status DeleteAndlnsertSub(UnkList &la, LinkList &lb, int i, int j, int len)LinkUst p, q, s, prev=NULL;int k=l;if(i<0|j<0| len<0) return INFEASIBLE;/在la表中查找第i个结点p=la;while(p&&k<i) prev=p;p=p->next;k+;if(!p)return INFEASIBLE;/在la表中查找第i+len-1个结点q=P; k=l;while(q&&k<len)(q=p->next;k+;)if(!q)return INFEASIBLE;/完成删除,注意,i=l的情况需要特殊处理 if(!prev) la=q->next;else prev->next=q->next;/将从la中删除的结点插入到lb中if(j=l)q->next=lb;lb=p;elses=lb; k=l;while(s&&k<j-l)s=s->next;k+;if(Is)return INFEASIBLE;q->next=s->next;s->next=p; 完成插入 return OK;i.2.17 试写一算法,在无头结点的动态单链表上实现线性表操作Insert (L,i,b),并和在带头结点的动态单 链表上实现相同操作的算法进行比较.2.18 试写一算法,实现线性表操作Deleted, i),并和在带头结点的动态单链表上实现相同操作的算法进 行比较.2.19 已知线性表中的元素以值递增有序排列,并以单链表作存储结构.试写一高效的算法,删除表中所有 值大于mink且小于maxk的元素(若表中存在这样的元素),同时释放被删结点空间,并分析你的算法的时 间复杂度(注意,mink和maxk是给定的两个参变量,它们的值可以和表中的元素相同,也可以不同).解:Status Li stDelete_I. (LinkU st &L, ElemType mi nk, ElemType maxk)(LinkList p, q, prev=NULL;i f(mink>maxk)return ERROR;P=L;prev=p;p=p->next;while(p&&p->data<maxk) i f(p->data<=mi nk)prev=p; p=p->next;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; whi le(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 试写一算法,实现顺序表的就地逆置,即利用原表的存储空间将线性表(%,4,)逆置为解:/顺序表的逆置Status ListOppose_Sq(SqList &L) ( int i;ElemType x;for(i=0;i<L length/2;i+) x=L. ;L. elemi=L. elemL. length-l-i;L. elemL. length-l-i=x; ) return OK;)2.22 试写一算法,对单链表实现就地逆置。解:/带头结点的单链表的逆置Status ListOppose_L(LinkList &L) (LinkList p, q;P=L; p=p->next; L->next=NULL; while(p) q二P; p=p->next; q->next=L->next; L->next=q; return OK;)2.23 设线性表4 = (4,。2, , ,,B 也,,b”),试写一个按下列规则合并A, B为线性表 C的算法,即使得C =当 mW 时:C =(。”"/一,明涉“,。”+1一,。,“)当 m> 时。线性表A, B和C均以单链表作存储结构,且C表利用A表和B表中的结点空间构成。注意:单链表的长度 值m和n均未显式存储。解:/将合并后的结果放在C表中,并删除B表Status Li stMerge_L(LinkList &A, LinkList &B, LinkLi st &C) (LinkU st pa, pb, qa, qb;pa=A->next:pb=B->next;C=A;whi1e(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 UstMergeOppose_L(LinkList &A, LinkList &B, LinkList &C) (LinklJst 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->data<pb->data)qa=pa;pa=pa_>next;

    注意事项

    本文(数据结构习题集答C语言版严蔚敏).docx)为本站会员(无***)主动上传,淘文阁 - 分享文档赚钱的网站仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知淘文阁 - 分享文档赚钱的网站(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于淘文阁 - 版权申诉 - 用户使用规则 - 积分规则 - 联系我们

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

    工信部备案号:黑ICP备15003705号 © 2020-2023 www.taowenge.com 淘文阁 

    收起
    展开