数据结构算法设计题

数据结构算法设计题

ID:15094890

大小:83.00 KB

页数:11页

时间:2018-08-01

数据结构算法设计题_第1页
数据结构算法设计题_第2页
数据结构算法设计题_第3页
数据结构算法设计题_第4页
数据结构算法设计题_第5页
资源描述:

《数据结构算法设计题》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、一、算法设计题1.设二叉树bt采用二叉链表结构存储。试设计一个算法输出二叉树中所有非叶子结点,并求出非叶子结点的个数。【答案】intcount=0;voidalgo2(BTNode*bt){if(bt){if(bt->lchild

2、

3、bt->rchild){printf(bt->data);count++;}algo2(bt->lchild);algo2(bt->rchild);}}2.阅读下列函数arrange()intarrange(inta[],int1,inth,intx){//1和h分

4、别为数据区的下界和上界inti,j,t;i=1;j=h;while(i=x)j--;while(i=x)i++;if(i

5、者之间,并返回数组中零元素的个数。【答案】(1)该函数的功能是:调整整数数组a[]中的元素并返回分界值i,使所有<x的元素均落在a[1..i]上,使所有≥x的元素均落在a[i+1..h]上。(2)intf(intb[],intn)或intf(intb[],intn){{intp,q;intp,q;p=arrange(b,0,n-1,0);p=arrange(b,0,n-1,1);q=arrange(b,p+1,n-1,1);q=arrange(b,0,p,0);returnq-p;returnp

6、-q;万维试题库系统第11页}}3.假设线性表以带表头结点的循环单链表表示。试设计一个算法,在线性表的第k个元素前插入新元素y。假如表长小于k,则插在表尾。【答案】voidalgo1(LNode*h,intk,ElemTypey){q=h;P=h->next;j=1;while(p!=h&&jnext;j++;}s=(LNode*)malloc(sizeof(Lnode));s->data=y;q->next=s;s->next=q;}4.二叉排序树的类型定义如下:ty

7、pedefstructBSTNode{∥二叉排序树的结点结构intdata;∥数据域structBSTNode*lchild,*rchild;∥左、右孩子指针}BSTNode,*BSTree;设计递归算法,统计一棵二叉排序树T中值小于a的结点个数。【答案】intf34(BSTreeroot){intcount;BSTNode*p;p=root;if(p&&p->datalchild);returncount;}5.设二叉树T采用二叉链表结构存储,试设计算法求出

8、二叉树中离根最近的第一个叶子结点。(注:结点按从上往下,自左至右次序编号)【答案】BTNode*Firstleaf(BTNode*bt){InitQueue(Q);//初始化队列Qif(bt){EnQueue(Q,bt);;while(!EmptyQueue(Q)){DeQueue(Q,p);if(!p->lchild&&!p->rchild)returnp;万维试题库系统第11页if(p->lchild)EnQueue(Q,p->lchild);if(p->rchild)EnQueue(Q,p

9、->rchild);}}}6.已知一棵具有n个结点的完全二叉树被顺序存储在一维数组中,结点为字符类型,编写算法打印出编号为k的结点的双亲和孩子结点。【答案】intalgo2(charbt[],intn,intk){if(k<1

10、

11、k>n)return0;if(k==1)printf(“%cisaroot”,bt[1]);elseprintf(“%c’sparentis%c”,bt[k],bt[k/2]);if(2*k<=n)printf(“%c’slchildis%c”,bt[k],

12、bt[2*k]);elseprintf(“%cisnotlchild”,bt[k]));if(2*k+1<=n)printf(“%c’srchildis%c”,bt[k],bt[2*k+1]);elseprintf(“%cisnotrchild”,bt[k]));return1;}7.编写算法,将非空单链表hb插入到单链表ha的第i(0next;p=p->next)

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。