首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。 【说明】 某应用中需要对100000个整数元素进行排序,每个元素的取值在0~5之间。排序算法的基本思想是:对每一个元素x,确定小于等于x的元素个数(记为m),将x放在输出元素序列的第m
阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。 【说明】 某应用中需要对100000个整数元素进行排序,每个元素的取值在0~5之间。排序算法的基本思想是:对每一个元素x,确定小于等于x的元素个数(记为m),将x放在输出元素序列的第m
admin
2014-11-13
31
问题
阅读下列说明和C代码,回答问题1至问题3,将解答写在答题纸的对应栏内。
【说明】
某应用中需要对100000个整数元素进行排序,每个元素的取值在0~5之间。排序算法的基本思想是:对每一个元素x,确定小于等于x的元素个数(记为m),将x放在输出元素序列的第m个位置。对于元素值重复的情况,依次放入第m—1、m一2、…个位置。例如,如果元素值小于等于4的元素个数有10个,其中元素值等于4的元素个数有3个,则4应该在数据元素序列的第10个位置、第9个位置和第8个位置上。算法具体的步骤为:
步骤1:统计每个元素值的个数。
步骤2:统计小于等于每个元素值的个数。
步骤3:将输入元素序列中的每个元素放入有序的输出元素序列。
【C代码】
下面是该排序算法的C语言实现。
(1)常量和变量说明
R常量,定义元素取值范围中的取值个数,如上述应用中R值应取6
i:循环变量
n:待排序元素个数
a:输入数组,长度为n
b:输出数组,长度为n
c:辅助数组,长度为R,其中每个元素表示小于等于下标所对应的元素值的个数。
(2)函数sort
voidsort(intn,inta[],intb[]){
intc[R],i;
for(i=0;i<(1);i++){
c
=0;
}
for(i=0;i
c[a
]=(2);
}
for(i=0;i
c
=(3);
}
for(i=0;i
b[c[a
]一1]=(4);
c[a
]=c[a
]一1;
}
}
根据说明和C代码,填充C代码中的空缺(1)~(4)。
选项
答案
(1)R(2)c[a[i]]+1(3)c[i]+c[i-1](4)a[i]
解析
在函数sort中,首先对辅助数组c进行初始化,将R个元素全部初始化为0,代码为:
for(i=0;i
c
=0;
}
然后,统计每个元素值的个数,元素的个数保存数组c中,c的下标表示对应的元素。通过循环读取元素
a
,每读取到一个a
,c[a
]的值变加1。代码为:
for(i=0;i
c[a
]=c[a
]+1;
}
接下来统计小于等于每个元素值的个数,用c
保存。输入数组的每个元素的取值在0~5之间,即有6种取值,0、1、2、3、4、5,则c[0]保存的是值为O的元素个数,c[1]保存的是值为1的元素个数,以此类推,c[5]保存的是值为5的元素个数。则小于等于O的元素个数有c[0]个,小于等于l的元素有c[0]+c[1]个,小于等于2的元素有c[0]+c[1]+c[2]个,依次类推,小于等于5的元素个数为c[0]+c[1]+c[2]+c[3]+c[4]+c[5]。代码为:for(i:0;i
c
=c
+c[i一1];
}
最后,将输入元素序列中的每个元素放入有序的输出元素序列。小于等于a
的元素有c[a
]个,由于c语言中,数组的下标从0开始,每读取的一个值为a
的元素,应保存到b[c[a
]一1],然后将c[a
]的值减1,c[a
]保存当前未保存到数组b中的值为a
的元素个数。代码为:
for(i=0;i
b[c[a
]一1]=a
;
c[a
]=c[a
]一1;
}
转载请注明原文地址:https://kaotiyun.com/show/KZDZ777K
本试题收录于:
软件设计师下午应用技术考试题库软考中级分类
0
软件设计师下午应用技术考试
软考中级
相关试题推荐
阅读以下说明,回答问题1至问题6。[说明]某单位局域网通过ISP提供的宽带线路与Internet相连,ISP分配的公网IP地址为202.117.12.32/29,局域网中一部分计算机通过代理服务器访问Internet,而另一部分计算机不经过代理
启动init进程前,不需要经过______步骤。A.LIIO加载内核B.检测内存C.加载文件系统D.启动网络支持inittab文件存放在______目录中。A./etc15./bootC
某交换机的配置命令如下,根据命令后面的注释,填写(1)~(3)处的空缺内容,完成配置命令。Switch(config)#(1)//将交换机命名为Sw1Swl(config)#interfacevlan1Swl(config
在“管理工具”中运行“管理IP筛选器列表”,创建一个名为“SNMP消息”的筛选器。在如图12-3所示的“IP筛选器向导”中指定IP通信的源地址,下拉列表框中应选择(1);在如图12-4中指定IP通信的目标地址,下拉列表框中应选择(2)。在图
在校园网设计过程中,划分了很多VLAN,采用了VTP来简化管理。1.VTP信息只能在(1)端口上传播。2.运行VTP的交换机可以工作在三种模式:(2)、(3)、(4)。3.共享相同VLAN数据库的交换机构成一个(5)。该校园网内
从网络拓扑图中可以看出该校园网采用了分层设计结构,回答以下问题:1.交换机按照所处的层次和完成的功能分为三种类型:核心交换机、汇聚交换机和接入交换机。下表是学校采购的三种交换机,请根据交换机的技术指标确定交换机的类型。在答题纸对应的解答栏内
在控制面板的“添加/删除程序”对话框中选择(1),然后进入“应用程序服务器”选项,在(2)组件复选框中选择“文件传输协议(FTP)服务”,就可以在Windows2003中安装FTP服务。(1)A.更改或删除程序B.添加新程序C.添加/删除
阅读以下说明,回答问题1至问题6。【说明】某公司要在Windows2003Server上搭建内部FTP服务器,服务器分配有一个静态的公网IP地址200.115.12.3。
1.路由器第一次设置时,必须通过Console口连接运行终端仿真软件的计算机进行配置,此时终端仿真程序设置的波特率应为(1)b/s。2.路由器有多种配置模式,请根据以下命令提示状态,判断路由器处于何种配置模式下。Router(Config)
随机试题
A.直腿抬高试验阳性B.拾物试验阳性C.两者皆有D.两者皆无脊柱结核可出现
轻度缺水是指人体缺水占体重的
经产妇,29岁,足月妊娠在家自然分娩,胎儿娩出1小时后胎盘未娩出而入院。诉产时顺利,娩出一中等大小男婴,分娩至现在阴道出血量中等。前次妊娠有人工剥离胎盘史,检查宫底平脐,轮廓清晰,膀胱空虚.宫口可容三指,软产道完整,脐带外露,胎盘未娩出最常见的原因可能是
A.胶艾汤B.大补阴丸C.六味地黄丸D.左归饮E.金匮肾气丸四物汤由何方化裁而来
A.败血症B.脓血症C.毒脓败血症D.菌血症E.毒血症大量毒素进入血液循环,引起剧烈的全身反应的疾病称为
采用了同步CDMA、智能天线、软件无线电、接力切换等一系列高新技术的全新移动通信技术是()。
A注册会计师负责审计甲公司2012年度财务报表。在编制和归整审计工作底稿时,A注册会计师遇到下列事项,请代为作出正确的专业判断。(根据2011年考题修订)在编制审计工作底稿时,下列各项中,A注册会计师通常认为不必形成最终审计工作底稿的是()。,
社会工作者在引导服务对象探索自己过去的经验时,经常采用引领性技巧。下列社会工作者的回应中,运用引领性技巧的有()。
下列选项中,能够吸引起随意注意的原因是()。(2015年)
在美国职业拳击比赛中,泰森将霍利菲尔德的耳垂咬掉,则泰森的行为侵犯了霍利菲尔德的()。
最新回复
(
0
)