版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Status Insert_Sq( SqList *La, ElemType x ) / 已知顺序表La 中元素依值非递减有序排列,本算法 / 插入新的元素 x 并保持原表的有序性,返回 OK; / 若顺序表空间已满,则不再插入并返回 OVERFLOW if (La-length = La-listsize) return OVERFLOW; i = 0; while (i length & x=La-elemi) i+; for ( j=La-length; ji; j- ) La-elemj = La-elemj-1; / 右移所有值x的元素 La-elemi = x; La-le
2、ngth+; return OK; /Insert_Sq2.2设顺序表设顺序表va中的数据元素递增有序。试写一算法,将中的数据元素递增有序。试写一算法,将x 插入到顺序表的适当位置上,以保持该表的有序性。插入到顺序表的适当位置上,以保持该表的有序性。 2.3试写一算法,在带头结点的单链表结构上实现线性表试写一算法,在带头结点的单链表结构上实现线性表 操作操作LOCATE(L, X)。 int LOCATE(LinkList L , ElemType X , Status(* compare)(ElemType , ElemType) /在带头结点的单链表L中查找第1个值与X满足compare(
3、)的元素的位序,若找到,则返回其在L中的位序,否则返回0i = 1;p = L-next;while (p & ! (* compare)( p-data , X ) p=p-next ; i +; if (p) return i; else return 0;2.4已知指针已知指针ha和和hb分别指向两个单链表的头结点,并且已知分别指向两个单链表的头结点,并且已知 两个链表的长度分别为两个链表的长度分别为m和和n。试写一算法,将这两个链表。试写一算法,将这两个链表 连接在一起(即令其中一个表的首元结点连在另一个表的连接在一起(即令其中一个表的首元结点连在另一个表的 最后一个结点之后)
4、,假设指针最后一个结点之后),假设指针hc指向连接后的链表的头指向连接后的链表的头 结点,并要求算法以尽可能短的时间完成连接运算。请分结点,并要求算法以尽可能短的时间完成连接运算。请分 析你的算法的时间复杂度。析你的算法的时间复杂度。 Connect ( LinkList *ha , LinkList *hb , LinkList *hc , int m , int n)/根据给定的两个链表的长度选择较短的链表并找到其尾结点。根据给定的两个链表的长度选择较短的链表并找到其尾结点。 LinkList *p , *q; if (mnext) p=p-next; p-next=q-next; fre
5、e(q); /释放头结点释放头结点 ha=hb=NULL; 时间复杂度时间复杂度T(n)=O(min(m,n)题题2.5删除有序表中所有其值大于 mink 且小于maxk的数据元素。首先分析需要删除的结点需要删除的结点的特点: mink =maxkpreqp修改指针修改指针: pre-next = p;释放结点释放结点: while (q!=p) s=q-next; free(q); q=s; void delete(LinkList &L, int mink, int maxk) / delete while (p & p-datanext; /查找第一个值mink的结点if
6、 (p) / ifq=pre-next; pre-next=p; / 修改指针while (q!=p) s=q-next; delete q; q=s; / 释放结点空间p=L-next; while (p & p-datanext; / 查找第一个值 maxk 的结点返回返回2.6 试写一算法,对单链表实现就地逆置,即利用原表的存储 空间将线性表(a1,a2,an)逆置为 (an,an-1,a1)。 void invert(LinkList *head) LinkList *p,*q,*r; p=head; q=p-next; while(q!=NULL) /当L没用后续节点时终止
7、r=q-next;q-next=p;p=q;q=r; /实现指针后移 head-next=NULL; head=p;/p指向L的最后一个结点,现改为头结点2.7 假设某个单向循环链表的长度大于假设某个单向循环链表的长度大于1,且表中既无头结点,且表中既无头结点 也无头指针。已知也无头指针。已知s为指向链表中某个结点的指针,试编写为指向链表中某个结点的指针,试编写 算法在链表中删除指针算法在链表中删除指针s所指结点的前驱结点。所指结点的前驱结点。 LinkList *delnode(LinkList *s) LinkList *q,*r; q=s; while(q-next!=s) q=q-ne
8、xt; r=q; while(r-next!=q) r=r-next; r-next=s; free(q); 2.8 已知有一个单向循环链表,其每个结点中含三个域:已知有一个单向循环链表,其每个结点中含三个域:prior, data和和next,其中,其中data为数据域,为数据域,next为指向后继结点的指针为指向后继结点的指针 域,域,prior也为指针域,但它的值为空(也为指针域,但它的值为空(NULL)。试编写算)。试编写算 法将此单向循环链表改为双向循环链表,即使法将此单向循环链表改为双向循环链表,即使prior成为指向成为指向 前驱结点的指针域。前驱结点的指针域。 typedef
9、struct Lnode Elemtype data; struct Lnode *next,*prior;struct LinkList *trans(struct LinkList *head) struct LinkList *p,*q; p=head-next; q=head; while(p!=head) /依次从左向右通过每个结点,对每个结点置依次从左向右通过每个结点,对每个结点置prior值。值。 p-prior=q; p=p-next; q=q-next) head-prior=q;/此时此时q指向最后一个结点,将第一个结点的指向最后一个结点,将第一个结点的 prior域指向最
10、后一个结点。域指向最后一个结点。 return(head);3.1 写出下列程序段的输出结果(栈的元素类型写出下列程序段的输出结果(栈的元素类型SElemType 为为char)。)。 void main() Stack S;char x, y;InitStack(S);x = c; y = k;Push(S, x); Push(S, a); Push(S, y); Pop(S, x); Push(S, t); Push(S, x);Pop(S, x); Push(S, s);while(!StackEmpty(S)Pop(S, y); printf(y);printf(x); 按照四则运算加
11、、减、乘、除和幂运算按照四则运算加、减、乘、除和幂运算()优先关系的惯例,并仿照教材例)优先关系的惯例,并仿照教材例3-2的格式,画出对下列算术表达式求值时的格式,画出对下列算术表达式求值时操作数栈和运算符栈的变化过程:操作数栈和运算符栈的变化过程: ABC/D+EF写出下列程序段的输出结果(队列中的元素类型写出下列程序段的输出结果(队列中的元素类型QElem Type为为char)。)。void main( ) Queue Q; Init Queue (Q); Char x=e; y=c; EnQueue (Q,h); EnQueue (Q,r); EnQueue (Q,y); DeQueue (Q,x); EnQueue (Q,x); DeQueue (Q,x); EnQueue (Q,a); while(!QueueEmpty(Q) DeQueue (Q,y);printf(y); ; Printf(x); 简述以下算法的功能(栈和队列的元素
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025国家电投集团数字科技有限公司招聘10人(第三批)备考核心题库及答案解析
- 2026河北省定向华中师范大学选调生招录备考考试题库及答案解析
- 2026福建龙岩市面向教育部直属师范大学、福建省复合型硕士层次公费师范毕业生“双向选择”专项招聘8人笔试重点题库及答案解析
- 2025广西百色市科学技术馆面向全市公开选调馆长1人参考考试试题及答案解析
- 2025年绥阳人民法院公开招聘聘用制书记员备考题库及一套参考答案详解
- 2025广西梧州市龙投人力资源有限公司招聘笔试重点试题及答案解析
- 中电科发展规划研究院有限公司2026届校园招聘备考题库及完整答案详解一套
- 2025年全球芯片代工市场竞争格局与产能扩张计划行业报告
- 2025年烟台市检察机关公开招聘聘用制书记员的备考题库(24人)及1套参考答案详解
- 中国火箭公司2026校园招聘考试重点题库及答案解析
- 湖北省鄂东南省级示范高中教育教学改革联盟2026届生物高二上期末复习检测试题含解析
- 科睿唯安 2025-年最值得关注的公司:蛋白质降解剂-使针对“不可成药”靶点的精准干预成为可能
- 中孕引产护理查房
- 公交司机服务规范与技能提升培训
- 福建省龙岩市龙岩北附2026届化学高一第一学期期末综合测试试题含解析
- 血透室护理组长竞选
- 2025-2026学年部编版八年级数学上册期中考试试卷及答案
- 实验室生物安全评估报告模板
- GB 38304-2025手部防护防寒手套
- 弱电智能化总体设计方弱电智能化总体设计方案
- 规范使用执法记录仪课件
评论
0/150
提交评论