ImageVerifierCode 换一换
格式:DOCX , 页数:23 ,大小:251.22KB ,
资源ID:14393753      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/14393753.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(数据结构c语言描述第二版标准答案耿国华西安电子科技大学Word格式文档下载.docx)为本站会员(b****4)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

数据结构c语言描述第二版标准答案耿国华西安电子科技大学Word格式文档下载.docx

1、【解答】 优点:当没有调用函数时,不占用内存,调用结束后形参被释放,实参维持,函数通用性强,移置性强。 缺点:形参须与实参对应,且返回值数量有限。(2)通过全局变量隐式传递减少实参与形参的个数,从而减少内存空间以及传递数据时的时间消耗函数通用性降低,移植性差算法如下:通过全局变量隐式传递参数PolyValue() int i,n;float x,a,p; printf(“nn=”); scanf(“%f”,&n); printf(“nx=”);x);for(i=0;n; scanf(“%f ”,&ai); /*执行次数:n次 */ p=a0; p=p+ai*x;n次*/ x=x*x;print

2、f(“%f”,p); 算法的时间复杂度:T(n)=O(n)通过参数表中的参数显式传递float PolyValue(float a , float x, int n) float p,s;int i;p=x; s=a0;for(i=1;s=s+ai*p; /*执行次数:n次*/ p=p*x;return(p);第2章 线性表习 题1.填空:(1)在顺序表中插入或删除一个元素,需要平均移动一半元素,具体移动的元素个数与插入或删除的位置有关。(2)线性表有顺序和链式两种存储结构。在顺序表中,线性表的长度在数组定义时就已经确定,是静态保存,在链式表中,整个链表由“头指针”来表示,单链表的长度是动态保

3、存。(3)在顺序表中,逻辑上相邻的元素,其物理位置一定相邻。在单链表中,逻辑上相邻的元素,其物理位置不一定相邻。(4)在带头结点的非空单链表中,头结点的存储位置由头指针指示,首元素结点的存储位置由头结点指示,除首元素结点外,其它任一元素结点的存储位置由其直接前趋的next域指示。2.选择题(1) A(2) 已知L是无表头结点的单链表,且P结点既不是首元素结点,也不是尾元素结点。按要求从下列语句中选择合适的语句序列。a. 在P结点后插入S结点的语句序列是:E、A。b. 在P结点前插入S结点的语句序列是:H、L、I、E、A。c. 在表首插入S结点的语句序列是:F、M。d. 在表尾插入S结点的语句序

4、列是:L、J、A、G。供选择的语句有:A P-next=S;B P-next= P-next-next;C P-next= S-D S-E S-next= L;F S-next= NULL;G Q= P;H while (P-next!=Q) P=P-I while (P-=NULL) P=P-J P= Q;K P= L;L L= S;M L= P;(3) D(4) D(5) D(6) A7试分别以不同的存储结构实现单线表的就地逆置算法,即在原表的存储空间将线性表(a1,a2,an)逆置为(an,an-1,a1)。(1)用一维数组作为存储结构 void invert(SeqList *L, i

5、nt *num) j; ElemType tmp;for(j=0;=(*num-1)/2; tmp=Lj;Lj=L*num-j-1;L*num-j-1=tmp;(2)用单链表作为存储结构 invert(LinkList L)Node *p, *q, *r; if(L-next =NULL) return; /*链表为空*/ p=L- q=p-p-next=NULL; /* 摘下第一个结点,生成初始逆置表 */while(q!=NULL) /* 从第二个结点起依次头插入当前逆置表 */r=q-q-next=L-L-next=q;q=r;11将线性表A=(a1,a2,am), B=(b1,b2,b

6、n)合并成线性表C, C=(a1,b1,am,bm,bm+1,.bn) 当mn时,线性表A、B、C以单链表作为存储结构,且C表利用A表和B表中的结点空间构成。单链表的长度值m和n均未显式存储。【解答】算法如下:LinkList merge(LinkList A, LinkList B, LinkList C) Node *pa, *qa, *pb, *qb, *p; pa=A- /*pa表示A的当前结点*/ pb=B-p=A; / *利用p来指向新连接的表的表尾,初始值指向表A的头结点*/ while(pa!=NULL & pb! /*利用尾插法建立连接之后的链表*/ qa=pa-qb=qb-

7、 p-next=pa; /*交替选择表A和表B中的结点连接到新链表中;*/p=pa;next=pb;p=pb;pa=qa;pb=qb;if(pa! /*A的长度大于B的长度*/ if(pb! /*B的长度大于A的长度*/C=A;Return(C);实习题约瑟夫环问题约瑟夫问题的一种描述为:编号1,2,n的n个人按顺时针方向围坐一圈,每个人持有一个密码(正整数)。一开始任选一个报数上限值m,从第一个人开始顺时针自1开始顺序报数,报到m时停止报数。报m的人出列,将他的密码作为新的m值,从他在顺时针方向上的下一个人开始重新从1报数,如此下去,直至所有的人全部出列为止。试设计一个程序,求出出列顺序。利

8、用单向循环链表作为存储结构模拟此过程,按照出列顺序打印出各人的编号。例如m的初值为20;n=7,7个人的密码依次是:3,1,7,2,4,8,4,出列顺序为6,1,4,7,2,3,5。typedef struct Nodeint password;int num;struct Node *next; Node,*Linklist;void Josephus() Linklist L; Node *p,*r,*q; int m,n,C,j; L=(Node*)malloc(sizeof(Node); /*初始化单向循环链表*/ if(L=NULL) printf(n链表申请不到空间!);retur

9、n; L- r=L; printf(请输入数据n的值(n0): scanf(%d,& for(j=1;j+) /*建立链表*/ p=(Node*)malloc(sizeof(Node); if(p!=NULL)请输入第%d个人的密码:,j);C);password=C;num=j; r-next=p; r=p;printf(请输入第一个报数上限值m(mm);*n出列的顺序为:n q=L; while(n!=1) /*计算出列的顺序*/ j=1; while(j j+;%d-,p-num); m=p-password; /*获得新密码*/ n-; q-next=p- /*p出列*/ free(r);%dn第3章 限定性线性表 栈和队列第三章答案1按3.1(b)所示铁道(两侧铁道均为单向行驶道)进行车厢调度,回答:(1) 如进站的车厢序列为123,则可能得到的出站车厢序列是什么?(2) 如进站的车厢序列为123456,能否得到435612和135426的出站序列,并说明原因(即写出以“S”表示进栈、“X”表示出栈的栈序列操作)。(1)可能得到的出站车厢序列是:123、132、213、231、321。(2)不能得到435612的出站序列

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

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