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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

本文(《软件技术基础》开放式考试试题.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

《软件技术基础》开放式考试试题.docx

1、软件技术基础开放式考试试题2010级 电气工程及自动化、自动化 专业软件技术基础课程开放式考试试题 任课教师:王 初 阳 姓 名: 闫 俊 鹏 学 号:100611327 递交日期:2012.04.23 成 绩: 试题1. 总结和比较线性表、堆栈、队列、二叉树、树、图的各种存储结构,并说明它们是如何使用数组和指针的。(10分) 答:A)线性表:线性表的四种存储结构即顺序存储,单链表存储,循环链表存储和双向循环链表存储结构。其特点为:(1)线性表中所有元素所占的存储空间是连续的。(2)线性表中各数据元素在存储空间中是按逻辑顺序依次存放的。在顺序存储结构下可以进行插入、删除、查找、排序、分解、合并

2、、复制、逆转等操作。存储时,其插入、删除、顺序输出都是通过数组来实现的。B)堆栈:栈是限定在一端进行插入与删除的线性表。堆栈遵循“先进后出”的原则组织数据的,栈是限定在一端进行插入和删除的线性表,包括栈顶指针和栈底指针,入栈、退栈和读栈都是在栈顶指针执行,当栈顶指针和栈底指针相等时表示为空栈,它具有记忆作用。堆栈一般可以实现入栈、退栈、读栈顶等运算。栈有两种存储结构顺序存储结构和链式存储结构。C)队列:是指允许在一端进行插入、而在另一端进行删除的线性表。队列遵循“先进先出”的原则进行入队、退队等运算的,队列的顺序存储结构一般采用循环队列的方式。既包括入队和退队两种基本运算。每进行性一次入队运算

3、,队尾指针就进一;每进行一次退队运算,排头指针就进一。队列有两种存储结构即顺序存储结构和链式存储结构。它有头指针和尾指针。队列中插入的元素只能在队尾指针插入,删除的元素只能在队头指针删除,一般采取循环队列的形式,在“上溢”时不能入队,在“下溢”时不能退队。D)二叉树:二叉树是非线性结构,即每个数据节点至多有一个前驱,但可以有多个后继。它可采用顺序存储结构和链式存储结构。顺序存储结构,就是用一组连续的存储单元存放二叉树中的节点。链式存储结构,是指用链表来表示一颗二叉树,即用链表指示元素的逻辑关系。二叉树的每一个结点有一个数据域和两个指针域,两个指针域分别指向左子树和右子树。它的遍历都是通过指针来

4、实现的。E)树:双亲链表表示法双亲链表表示法利用树中每个结点的双亲唯一性,在存储结点信息的同时,为每个结点附设一个指向其双亲的指针,惟一地表示任何-棵树。孩子链表表示法孩子链表表示法是为树中每个结点设置一个孩子链表,并将这些结点及相应的孩子链表的头指针存放在一个向量中。 孩子兄弟链表表示法孩子兄弟链表表示法是指在存储结点信息的同时,附加两个分别指向该结点最左孩子和右邻兄弟的指针域,即可得树的孩子兄弟链表表示。注意:这种存储结构的最大优点是:它和二叉树的二叉链表表示完全一样。可利用二叉树的算法来实现对树的操作。F)图:如果数据元素集合中的各数据元素之间存在任意的前后件关系,则此数据结构称为图。图

5、的存储结构有关联矩阵、求值矩阵、邻接表、和临界多重表。 关联矩阵:关联矩阵可以首先用一个长度为n的一维数组D来存放图中各数据节点信息,再用一个二维数组R来存放图中各节点的关联信息。其中R称为图的关联矩阵。在关联矩阵R中,每当一个元素R(i,j)=1时,d(i)是d(j)的前件,当R(i,j)=0时,d(i)不是d(j)的前件。求值矩阵:假设有值图有n个节点,则求值矩阵是一个n阶矩阵,其中第i行、第j列的元素V(i,j)表示有值图中第i个结点到第j个结点的求值函数f(di,dj),当第i个结点到dj个结点不存在边时,可以置与求值函数的一切函数值不同的其他值,实际应用中由于一般的求值函数的函数值为

6、正数,因此,当第i个节点到第j个节点不存在边时,置V(i,j)为-1。邻接表:也称为“顺序索引链接”存储结构,首先,每个存储结点都有一个指针域和一个数据域两个域。数据域来存放各节点的信息,指针域用于链接相应节点的后件。其次,对于图中的每一个节点构造一个单链表。邻接多重表:在图中每一条边连接了两个节点,每条边用一个存储节点表示,每个存储结点由五个域组成,分别为标志域、两个指针域和与该边关联的两个结点。2. 斐波那契数列问题。(1) 编写求解斐波那契数列中第n个数的递归和非递归c/c+函数;(2)编写main函数,测试n=10,20,30,40,50时,上述递归和非递归c/c+函数的执行时间。(1

7、0分)/*所用的计时器为计算机CPU的计数器,因为第50个数太大了,所以得出的值是错的*/#include#include#includelong digui(int n) /递归算法 ,从上往下算 long s; if(n=0 | n=1) /递归终止条件 return n; else return s=digui(n-1)+digui(n-2); /根据公式来递归调用 long fdigui(int n) /非递归算法,从下往上算 long s,i,k,j; k=0; j=1; if(n=0 | n=1) return s=n; else for(i=2;i=n;i+) /根据公式求得此算

8、法 s=k+j; k=j; j=s; return s;int main() LARGE_INTEGER start,end; int n,i; long s; int a5=10,20,30,40,50; printf(非递归:n); for(i=0;i5;i+) QueryPerformanceCounter(&start); /得出用cpu计数器表示的时间 ,开始 s=fdigui(ai); /非递归 QueryPerformanceCounter(&end);/得出用cpu计数器表示的时间 ,开始 printf( 第%d个数是:%ld,ai,s); printf( 所用时间:%dn,e

9、nd.QuadPart-start.QuadPart); /算出所用时间 printf(递归:n); /同上 for(i=0;i5;i+) QueryPerformanceCounter(&start); s=digui(ai); QueryPerformanceCounter(&end); printf( 第%d个数是:%ld,ai,s); printf( 所用时间:%dn,end.QuadPart-start.QuadPart); 3. 括号匹配问题。(1) 编写c/c+函数,验证一个字符串形式的表达式中的括号是否匹配,其中括号包括圆括号、方括号和花括号。(2) 编写main函数从键盘读入

10、表达式,并调用你编写的函数。(10分)/输入的表达式如果匹配则输出yes,否则输出no #include#include#includetypedef struct char ch100; int length;biaoda; /一个栈 int check(biaoda *p) int s=1; int i; biaoda a; a.length=0; for(i=0;ilength;i+) if(p-chi=(|p-chi=|p-chi=) /将各个左括号存入栈中 a.cha.length=p-chi; a.length+; else if(p-chi=)|p-chi=|p-chi=)/如果

11、是右括号 if(p-chi=&a.cha.length-1!=|p-chi=)&a.cha.length-1!=(|p-chi=&a.cha.length-1!=) /检查是否与栈末尾的左括号匹配 s=0; else a.length-; /匹配的话则出栈一次 if(s=0) break; if(a.length!=0) s=0; if(s=0) /s为0表示不匹配,否则匹配 printf(NOn); else printf(YESn);int main() biaoda *p; p=(biaoda *)malloc(sizeof(biaoda); p-length=0; printf(请循环

12、输入表达式,以00结束:); /可以检测多个公式 while(gets(p-ch) if(p-ch0=0&p-ch1=0) /输入公式 break; p-length=strlen(p-ch); /栈的长度 check(p); 4. 排序问题。(1) 编写简单插入排序和基于二分查找的插入排序算法的c/c+函数;(2)设待排序数据个数为n,为每个n设计10个随机实例,然后测试当n大于多少时,二基于二分查找的插入排序的平均运行时间比简单插入排序算法的平均运行时间少四分之一。平均运行时间指对每个n的10个随机实例上的运行时间的平均值。(15分)#include#include#include#inc

13、lude#include#define MaxSize 100 typedef struct int dataMaxSize; int length;Num; /含有一个数组的结构体 void DirectInsertSort(Num *p) / 简单插排法 int k,key,i,j; if (p-length = 0) /检验是否为空 return; for (i = 1; i length; i+) /从第一个元素开始,将排好的元素放在左边,未排好的放在右边,并依次将右边的插入左边 for (j = 0; j datai dataj) /从左边开始找,直到找到比插入值大的值 key=p-

14、datai; for (k = i; k j; k-) /将插入位置后的数依次后移一位 p-datak=p-datak-1; p-dataj = key; /插入值 break; void BInsertSort(Num *p) /二分插排法 int i,j,low,high,mid,key; for(i=1;ilength;i+) key=p-datai; /将Ri暂存到key low=0; high=i-1; while(low=high) /在low.high中折半查找有序插入的位置 mid=(low+high)/2; /折半 if (keydatamid) high=mid-1; /插

15、入点在低半区 else low=mid+1; /插入点在高半区 for(j=i-1;j=high+1;j-) p-dataj+1=p-dataj; /记录后移 p-datahigh+1=key; /插入 int main() Num *p,*q; /声明两个指针,分别被两种算法用 int s,n=2,i=0,f; LARGE_INTEGER start,end; float atime1,atime2,avtime1,avtime2; /声明各种时间 p=(Num *)malloc(sizeof(Num); p-length=0; q=(Num *)malloc(sizeof(Num); q-

16、length=0;printf(首先检验排序法正确不:n 请输入元素,以00结束:); /检验排序法 scanf(%d,&s); while(s!=00) p-datap-length+=s; scanf(%d,&s); /输入元素 printf(n 排序后:);BInsertSort(p); /排序 for(s=0;slength;s+) /输出排序后的序列 printf( %d,p-datas); printf(n);p-length=0; while(1) atime1=0; atime2=0; for(i=0;i10;i+) /循环生成十个有n个数的序列 for(s=0;sdatap-

17、length+=f; q-dataq-length+=f; QueryPerformanceCounter(&start); /用的是CPU的计数器,较为精确 DirectInsertSort(p); QueryPerformanceCounter(&end); atime1+=(end.QuadPart-start.QuadPart); QueryPerformanceCounter(&start); BInsertSort(q); QueryPerformanceCounter(&end); atime2+=end.QuadPart-start.QuadPart; /atime2,atim

18、e1是两种算法的运行总时间 avtime1=atime1/10; /平均时间 avtime2=atime2/10; if(avtime2/avtime1=0.75) /判断是否达到条件 printf(当n大于等于%d时,基于二分查找的插入排序的平均运行时间比简单插入排序算法的平均运行时间少四分之一n,n); break; /符合条件的话中断循环 n+; 5. 二叉树的层次遍历。设二叉树的存储结构为二叉链表,数据元素类型为整数,(1) 编写二叉树前序建立二叉树的c/c+函数;(2) 编写该二叉树的层次遍历的代码;(3)编写main函数,从文件读入二叉树的前序序列,建立二叉树,并输出层次遍历序列。

19、(15分)#include#include#define MaxSize 64 typedef struct BiTreeNode int data; struct BiTreeNode *lchild; struct BiTreeNode *rchild; BiTreeNode; /节点的结构体 BiTreeNode *createBiTree() /先序生成二叉树 BiTreeNode *pt; /根节点 int n; scanf(%d,&n); /输入节点信息 if(n=00) pt = NULL; /如果输入为00,则返回空值 else pt = (BiTreeNode *)mallo

20、c(sizeof(BiTreeNode); pt-data = n; /赋值 pt-lchild = createBiTree(); /循环调用 pt-rchild = createBiTree(); return pt; void LevelOrder(BiTreeNode *b) /层次遍历函数 BiTreeNode *p; BiTreeNode *quMaxSize; /建立一个地址数组队列,用来存放节点地址 int front,rear; front=rear=-1; rear+; qurear=b; /首先存入根节点 while(front!=rear) /一边存地址,一边存地址,直

21、到全部输出 front=(front+1)%MaxSize; p=qufront; printf(%d ,p-data); if(p-lchild!=NULL) /依次将数组中各个节点的孩子存入数组 rear=(rear+1)%MaxSize; qurear=p-lchild; if(p-rchild!=NULL) rear=(rear+1)%MaxSize; qurear=p-rchild; int main() BiTreeNode *root; printf(建立先序二叉树,请输入元素,其中00即为空,且对叶子的孩子也要输入00表示为空,请注意输入:n); root=createBiTr

22、ee(); /建立二叉树 printf(层次遍历:); LevelOrder(root); /层次遍历 printf(n); 6. 树的层次遍历一。设树的存储结构为孩子链表,数据元素类型为整数,(1) 编写建立树的c/c+函数;(2) 编写该树的层次遍历的代码;(3)编写main函数,从文件读入并建立树,并输出层次遍历序列。(20分)/*输入时请注意不要输错,此代码不能纠错*/ #include#includetypedef struct cnode int child; struct cnode *next;link;typedef struct int data; link *headpt

23、r;ctree;ctree T50;int creatTree() int n=0,s,m; link *p,*q; T0.headptr=(link *)malloc(sizeof(link); T0.headptr-child=1; T0.headptr-next=NULL; printf(请输入你想要生成的树的所有节点值,默认以第一个节点为根节点,以00结束:); scanf(%d,&s); /输入各节点元素 while(s!=00) /输入为00表示输入结束 T+n.data=s; Tn.headptr=NULL; scanf(%d,&s); printf(各个元素的 序号-值 映射是

24、:); for(s=1;s=n;s+) printf(%d-%dt,s,Ts.data); /序号-值的映射 关系 printf(n请分别输入各个节点(用序号表示)的孩子的序号,以0结束:n); for(s=1;schild=m; p-next=NULL; if(Ts.headptr=NULL) Ts.headptr=p; q=p; else q-next=p; q=p; scanf(%d,&m); return n; int main() int n,rear,i,front; link *p; p=NULL; n=creatTree(); /生成树的结点个数 int check50=0;

25、/表示对应的结点是否被访问过 check0=1; ctree T150; /用来顺序存储层次遍历出的树的各个结点 printf(层次遍历:); T10=T0; T11=T1; check1=1; front=1; rear=1; /*依次将层次遍历出的树的各个结点 放入数组T1 */ for(;rearchild=0) T1+rear=Tp-child; checkp-child=1; /表示被访问过,1表示访问过 p=p-next; if(p=NULL) break; front+; for(i=1;i=n;i+) /输出遍历结果 printf( %d,T1i.data); 7. 完全二叉树

26、的存储结构变换。给定一个数组存储的完全二叉树,(1) 编写c/c+函数将完全二叉树的数组存储结构转换为二叉链表;(2)编写main函数,验证你的转换函数。(20分)#include#includetypedef struct int s100; int length;tree; /用数组存储的二叉树 typedef struct node int data; struct node *lchild; struct node *rchild; linklist; /用链表存储的二叉树的结点 linklist *change(tree *p) /转换二叉树的存储结构 int i; linklist *q100;

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

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