首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读下列说明和C代码,回答【问题1】至【问题3】,将解答写在答题纸的对应栏内。 【说明】 采用归并排序对n个元素进行递增排序时,首先将n个元素的数组分成各含n/2个元素的两个子数组,然后用归并排序对两个子数组进行递归排序,最后合并两个已经排
阅读下列说明和C代码,回答【问题1】至【问题3】,将解答写在答题纸的对应栏内。 【说明】 采用归并排序对n个元素进行递增排序时,首先将n个元素的数组分成各含n/2个元素的两个子数组,然后用归并排序对两个子数组进行递归排序,最后合并两个已经排
admin
2015-12-01
72
问题
阅读下列说明和C代码,回答【问题1】至【问题3】,将解答写在答题纸的对应栏内。
【说明】
采用归并排序对n个元素进行递增排序时,首先将n个元素的数组分成各含n/2个元素的两个子数组,然后用归并排序对两个子数组进行递归排序,最后合并两个已经排序的子数组得到排序结果。
下面的C代码是对上述归并算法的实现,其中的常量和变量说明如下:
arr:待排序数组
P,q,r:一个子数组的位置从P到q,另一个子数组的位置从q+1到r
begin,end:待排序数组的起止位量
left,right:临时存放待合并的两个子数组
n1,n2:两个子数组的长度
i,j,k:循环变量
mid:临耐变量
【C代码】
#inciude<stdio.h>
#inciude<stdlib.h>
Define MAX 65536
void merge(int arr([],int P,int q,int r){
int*left,*right;
int nl,n2,I,J,k;
n1=q—P+1:
n2=r—q:
If(left=(int*)malloc((nl+1)*sizeof(int)))=NULL)(
Perror(“malloc error”):
exit(1);
}
If((right=(int*)malloc((n2+1)*sizeof(int)))=NULL){
Perror(“malloc error”);
exit(1);
}
for(i=0;i<nl;i++){
left
=arr[p+i];
}
left
=MAX;
for(i=0;i<n2;i++){
right
=arr[q+i+1]
}
right
=MAX;
i=0;j=0;
For(k=p;(1);k++)(
If(1eft
>right[j]{
(2)
j++;
)else{
arr[k1]=left
;
i++:
}
}
}
Void merge Sot-t(int arr(),int begin,int end){
int mid:
if( (3) ){
mid=(begin+end)/2;
merge Sort (arr,begin,mid);
(4) ;
Merge(arr,begin,mid,end);
}
}
【问题1】
根据以上说明和C代码,填充(1)一(4)。
【问题2】
根据题干说明和以上C代码,算法采用了(5)算法设计策略,分析时间复杂度时,列出其递归式位 (6) ,接触渐进时间复杂度 (7) (用O符号表示)。空间复杂度为 (8) 。(用O符号表示)
【问题3】
两个长度分别为n1和n2的已经排好序的子数组进行归并,根据上述C代码,则元素之间比较次数为 (9) 。
选项
答案
【问题1】 (1)k<=r (2)arr[k]=right[j] (3)begin<end (4)mergeSort(arr,mid+1,end) 【问题2】 (5)分治 (6)T(n)=2T(n/2)+O(n) (7)O(nlogn) (8)O(n) 【问题3】 (9)n1+n2
解析
【问题1】
首先,函数void merge(int arr[],int P,int q,int r)的意思是:对子数组arr[p…q3和子数组arr[q+L..r3进行合并。因此第一空为k<=q;由于是采用归并排序对n个元素进行递增排序,所以第二空是将left
和right[j]的小者存放到arr[k]中去,即arr[k]=right[j]:当数组长度为1时,停止递归,因为此时该数组有序,则第三空为begin<end,即数组至少有两个元素才进行递归。合并了begin到mid之间的元素,继续合并mid+1到end之间的元素,则第四空为mergeSort(arr,mid+1,end)。
【问题2】
归并算法实际上就是将数组一直往下分割,直到分割到由一个元素组成的n个子数组,再往上两两归并。
将数组进行分割需要logN步,因为每次都是讲数组分割成两半(2x=N,x=logN)。
合并N个元素,需要进行N步,也就是O(N),则总的时间复杂度为O(NlogN)。
合并过程中,使用了n个中间变量存储,left=(int*)malloc((nl+1)*sizeof(int))。所以空间复杂度为O(n)。
推导递归式:
假设n个元素进行归并排序需要T(n),可以将其分割成两个分别有n/2个元素的数组分别进行归并,也就是2T(n/2),在将这两个合并,需要O(n)的时间复杂度,则推导公式为T(n)=2T(n/2)+O(n)。
转载请注明原文地址:https://www.kaotiyun.com/show/xdDZ777K
本试题收录于:
软件设计师下午应用技术考试题库软考中级分类
0
软件设计师下午应用技术考试
软考中级
相关试题推荐
阅读以下关于在Linux系统中配置Apache服务器的说明,回答问题1至问题3,将解答填入解答栏内。【说明】在Linux系统中采用Apache配置Web服务器。Apache服务器提供了丰富的功能,包括:目录索引、目录别名、虚拟主机、HTTP日志报
阅读下列说明,回答问题1至问题6,将解答填入解答栏内。【说明】某公司的两个部门均采用Windows2003的NAT功能共享宽带连接访问Internet,其网络结构和相关参数如下图所示。ISP为该公司分配的公网IP地址段为202.117.12.3
为了使DNS_Server1能正确解析本地Web站点的域名,需对DNS_Server1中的DNS服务进行配置。在图1所示的对话框中,新建的区域名称是(1);在图2所示的对话框中,添加的新建主机名称为(2),IP地址栏应填入(3)。DNS_Server
与ISDN相关的网络设备主要有TA、NT1、NT2、TE1、TE2等。在图2-9所示的网络拓扑结构中,路由器Router1和ISDN之间是否需要加入终端适配器(TA)?请用150字以内的文字简要说明理由。以下是在路由器Router1上的部分配置信息,结
如果ping127.0.0.1(本地循环地址),如果该地址无法Ping通,则说明了是什么原因?什么命令是一个监控TCP/IP网络的实用的工具,它可以显示实际的网络连接以及每一个网络接口设备的状态信息?什么命令是把网卡物理地址与IP静态地址捆绑在一起?
如果ping127.0.0.1(本地循环地址),如果该地址无法Ping通,则说明了是什么原因?在DOS状态下输入tracertwww.ciu.net.cn并执行后,经过一段时间等待,系统会反馈出很多IP地址。出现在最上方(第1条记录)的IP地址是什么
阅读以下关于网络地址转换(NAT)的技术说明,结合网络拓扑图回答问题1至问题3。【说明】网络地址转换(NAT)技术可用来缓解IP地址短缺问题和实现TCP负载均衡功能。动态地址翻译技术在子网外部使用少量的全局地址,通过路由器进行内部和外部地址的转换
请指出图1-12中(1)空缺处传输的是模拟信号,还是数字信号?在图1-12所示的网络拓扑图中,欲使内部网具有构造虚拟网的功能,图中(5)空缺处的交换机应具有哪些功能?
阅读以下某单位宽带网络接入的技术说明,根据要求回答问题1至问题6。【说明】接入网(AN)泛指用户网络接口(UNI)与业务节点接口(SNI)间实现传送承载功能的实体网络。其目标是建立一种标准化的接,方式,以一个可监控的接入网络,使用户能够获得话音、
简述网络规划阶段需求分析的方法和解决的问题。(控制在100个字以内)在需求分析过程中应对已有网络的现状及运行情况作调研,如果要在已有的网络上作新的网络建设规划,如何保护用户已有投资?(控制在100个字以内)
随机试题
甲公司有关投资业务资料如下,假定各方盈余公积计提的比例均为10%。有关资料如下:(1)2011年7月1日,甲公司以银行存款15000万元从其他股东处购买了乙公司20%的股权。甲公司与乙公司的原股东在交易前不存在任何关联方关系,当日乙公司可辨认净资产的公允
下列关于牵张反射的叙述,错误的是
气胸叩诊时呈()
将氯气通入石灰中而制成的混合物为
实木复合地板面层铺设时,相邻板材接头位置应错开不小于()mm距离。
首席风险官对于侵害客户和期货公司合法权益的指令或者授意应当予以拒绝;必要时,应当及时向()报告。
资料一东方公司是国内一家以彩电为主的大型家电生产企业。进入21世纪后,随着中国加入WTO,国外家电企业开始了第二轮对华投资热潮,抢夺彩电产业高端市场。国产彩电企业面临竞争白热化及核心技术缺失、利润空间缩小,国内市场饱和的压力。东方公司开始把目光转向
Patienceisofgreatimportanceinourdailylife.OnceIwaitedabustocomeatastop.30minutespast,butnobuscame.Both
已知线性方程组的通解为[2,1,0,1]T+k[1,-1,2,0]T.记αj=[a1j,a2j,a3j,a4j]T,j=1,2,…,5.问:α4能否由α1,α2,α3线性表出,说明理由.
Forthousandsofyears,peoplethoughtofglassassomethingbeautifultolookat.Onlyrecentlyhavetheycometothinkofita
最新回复
(
0
)