版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、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-1;i-)va.elemi=va.elemi-1;va.elemi=x;va.length+;return OK;2.14 试写一算法在带头结点的单链表结构上实现线
2、性表操作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.21 试写一算法,实现顺序表的就地逆置,即利用原表的存储空间将线性表逆置为。解:/ 顺序表的逆置Status ListOppose_Sq(SqList &L)int i;ElemType x;for(i=0;i<L.length/2;i+)x=L.elemi;L.elemi=L.elemL.length-1-i;L.elemL
3、.length-1-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;3.9 解:void ditui(int j)if(j>1)cout<<j;ditui(j-1);return;3.10解:void test(int &sum)Stack s;In
4、itStack(s);int x;docin>>x;Push(s,x);while(x>0);while(!StackEmpty(s)Pop(s,x);sum+=x;cout<<sum<<endl;DestoryStack(s);3.24 解:int g(int m,int n);int main()int m,n;cout<<"请输入m和n的值:"cin>>m>>n;if(n>=0) cout<<g(m,n)<<endl;else cout<<"
5、;No Solution!"return 0;int g(int m,int n)if(m>0)return(g(m-1,2*n)+n);else return 0;假设主函数的返回地址为0,递归函数3条语句的地址分别为1、2、3。306431323216338344052Status g(int m,int n,int &s)/求递归函数g的值s if(m=0&&n>=0) s=0; else if(m>0&&n>=0) s=n+g(m-1,2*n);
6、else return ERROR; return OK;/g3.31解:Status SymmetryString(char* p)Queue q;if(!InitQueue(q) return 0;Stack s;InitStack(s);ElemType e1,e2;while(*p)Push(s,*p);EnQueue(q,*p);p+;while(!StackEmpty(s)Pop(s,e1);DeQueue(q,e2);if(e1!=e2) return FALSE;return OK;(int Palindrome_Test()/判别输入的字符串是否回文序列
7、,是则返回1,否则返回0 InitStack(S);InitQueue(Q); while(c=getchar()!='') Push(S,c);EnQueue(Q,c); /同时使用栈和队列两种结构 while(!StackEmpty(S) Pop(S,a);DeQueue(Q,b); if(a!=b)
8、return ERROR; return OK;/Palindrome_Test 6.41 解:/ 求位于先序序列中第k个位置的结点的值,/ e中存放结点的返回值,i为计数器Status PONodeK(TElemType& e,int& i,int k,BiTree& T)if(T)i+;if(i=k) e=T->data;elsePONodeK(e,i,k,T->lchild);PONodeK(e,i,k,T->rchild);return OK;6.42 解:/ 求二叉树中叶子结点的数目Status
9、POLeafNodeNum(int& i,BiTree& T)if(T)if(!T->lchild && !T->rchild) i+;POLeafNodeNum(i,T->lchild);POLeafNodeNum(i,T->rchild);return OK;7.22 算法基本思想:递归算法,当两个顶点相等时为递归出口。否则递归调用。访问标志数组 DFS_locate(G g,int i,int j) int visitedMAXSIZE;ArcNode *w;int k;if(i=j) return 1;els
10、e visiti=1;for(w=g.verticesi.firstarc;w;w=w->nextarc) k=w->adjvex;if(!visitk&&DFS_locate(g,k,j) return 1;else return 0;7.23 int exist_path_BFS(ALGraph G,int i,int j)/广度优先判断有向图G中顶点i到顶点j是否有路径,是则返回1,否则返回0 。使用辅助队列Q和访问标志数组visited. int k ;ArcNode *p; int visitedMAXSIZE; InitQueue
11、(Q); EnQueue(Q,i); / i入队列 while(!QueueEmpty(Q) DeQueue(Q,u); / 对头元素出队并置为U visitedu=1; for(p=G.verticesi.firstarc ; p ;p=p->nextarc)
12、160; k=p->adjvex ; if(k=j) return 1 ; if(!visitedk) EnQueue(Q,k); /for /while return 0;/exist_path_BFS 9.25int Search_Sq(SSTable ST,int key)/在有序表上顺序查找的算法,监视哨设在高下标端 ST.elemST.length+1.key=key; for(i=1;ST
13、.elemi.key>key;i+); if(i>ST.length|ST.elemi.key<key) return ERROR; return i;/Search_Sq分析:本算法查找成功情况下的平均查找长度为ST.length+1/2,不成功情况下为ST.length+2/2. 9.26int Search_Bin_Recursive(SSTable ST,int key,int low,int high)/折半查找的递归算法 if(low>high) return 0; /查找不到时返回0
14、mid=(low+high)/2; if(ST.elemmid.key=key) return mid; else if(ST.elemmid.key>key) return Search_Bin_Recursive(ST,key,low,mid-1); else return Search_Bin_Recursive(ST,key,mid+1,high); /Search_Bin_Recursive 9.32int last=0; void MaxLT_MinGT(BiTree T,int x
15、)/找到二叉排序树T中小于x的最大元素和大于x的最小元素 if(T->lchild) MaxLT_MinGT(T->lchild,x); /本算法仍是借助中序遍历来实现 if(last<x&&T->data>=x) /找到了小于x的最大元素 printf("a=%dn",last); if(last<=x&&T->data>x) /找到了大于x的最小元素
16、 printf("b=%dn",T->data); last=T->data; if(T->rchild) MaxLT_MinGT(T->rchild,x);/MaxLT_MinGT 10.26void Bubble_Sort1(int a ,int n)/对包含n个元素的数组a进行改进的冒泡排序 change=n-1; /change指示上一趟冒泡中最后发生交换的元素的位置 while(change) for(c=0,i=0;i<change;i+) if(ai>ai+1) ai<-
17、>ai+1; c=i+1; /c指示这一趟冒泡中发生交换的元素的位置 change=c; /while/Bubble_Sort110.31 void Divide(int a ,int n)/把数组a中所有值为负的记录调到非负的记录之前 low=0;high=n-1; while(low<high) while(low<high&&ahigh>=0) high-; /以0作为虚拟的枢轴记录 alo
18、w<->ahigh; while(low<high&&alow<0) low+; alow<->ahigh; /Divide 10.33void LinkedList_Select_Sort(LinkedList &L)/单链表上的简单选择排序算法 for(p=L;p->next->next;p=p->next) q=p->next;x=q->data; for(r=q,s=q;r->ne
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 教师年度考核个人述职报告范文(19篇)
- 班主任教师工作简述7篇
- 智慧安全政务云数据中心整体解决方案
- 某文旅景区概念性策略-策划案例
- 《治安管理处罚法》知识竞赛参考试题库150题(含答案)
- 2025年武汉铁路职业技术学院高职单招职业适应性测试近5年常考版参考题库含答案解析
- 2025年无锡城市职业技术学院高职单招语文2018-2024历年参考题库频考点含答案解析
- 2025年曹妃甸职业技术学院高职单招语文2018-2024历年参考题库频考点含答案解析
- 特种材料供应合同
- 二手设备的买卖合同范本
- 2025年度厨师职业培训学院合作办学合同4篇
- 《组织行为学》第1章-组织行为学概述
- 市场营销试题(含参考答案)
- 2024年山东省泰安市高考物理一模试卷(含详细答案解析)
- 护理指南手术器械台摆放
- 肿瘤患者管理
- 四川省成都市高新区2024年七年级上学期语文期末试卷【含答案】
- 2025年中国航空部附件维修行业市场竞争格局、行业政策及需求规模预测报告
- 《应收培训》课件
- 国土空间生态修复规划
- 2024年医疗器械经营质量管理规范培训课件
评论
0/150
提交评论