首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下说明和C代码,填写程序中的空缺,将解答写入答题纸的对应栏内。 【说明】 规定整型数组a中的元素取值范围为[0,N),函数usrSort(int n,int a[])对非负整型数组a的前n个元素进行计数排序。排序时,用temp_arr[i]表
阅读以下说明和C代码,填写程序中的空缺,将解答写入答题纸的对应栏内。 【说明】 规定整型数组a中的元素取值范围为[0,N),函数usrSort(int n,int a[])对非负整型数组a的前n个元素进行计数排序。排序时,用temp_arr[i]表
admin
2021-03-24
61
问题
阅读以下说明和C代码,填写程序中的空缺,将解答写入答题纸的对应栏内。
【说明】
规定整型数组a中的元素取值范围为[0,N),函数usrSort(int n,int a[])对非负整型数组a的前n个元素进行计数排序。排序时,用temp_arr
表示i在数组a中出现的次数,因此可以从0开始按顺序统计每个非负整数在a中的出现次数,然后对这些非负整数按照从小到大的顺序,结合其出现次数依次排列。
例如,对含有10个元素{0,8,5,2,0,1,4,2,0,1}的数组a[]排序时,先计算出有3个0、2个1、2个2、1个4、1个5和1个8,然后可确定排序后a的内容为{0,0,0,1,1,2,2,4,5,8}。
下面代码中用到的memset函数的原型如下,其功能是将p所指内存区的n个字节都设置为ch的值。
void
*
memset(void
*
p,int ch,size_t n);
【C代码】
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 101
void printArr(int a[],int n);
void usrSort(int n,int a[]);
int main()
{
int a [10]={0,8,5,2,0,1,4,2,0,1};
printArr(a,sizeof(a)/sizeof(int));
(1)
; //调用usrSort()对数组a进行升序排序
printArr(a,sizeof(a)/sizeof(int));
return 0;
}
void printArr(int a[],int n)
{
int i;
for(i=0;i<n;i++)
printf("%d",a
);
printf("in");
}
void usrSort(int n,int a[])
{
int i,k;
int
*
temp_arr; //用temp_arr
表示i在a中出现的次数
temp_art=(int
*
)malloc(N
*
sizeof(int));
if(!temp_arr)return;
//将所申请并由temp_art指向的内存区域清零
memset(
(2)
);
for(i=0;i<n;i++)
temp_err[
(3)
]++;
k=0;
for(i=0;i<N; i++){
int cnt; //cnt表示i在数组a中的出现次数
(4)
;
while(cnt>0){
a[k]=i; //将i放入数组a的适当位置
(5)
;
cnt-;
}
}
free(temp_arr);
}
选项
答案
(1)usrSort(10,a)或等效形式,a可替换为&a,&a[0]。 (2)temp_art,0,N
*
sizeof(int)或等效形式,其中N和sizeof(int)可替换为101、4。 (3)a[i]或
*
(a+i)或等效形式。 (4)cnt=temp_arr[i]或cnt=
*
(temp_arr+i)或等效形式。 (5)k++或++k或k=k+1或k+=1或等效形式。
解析
本题考查考生对C程序基本结构、函数定义及调用和运算逻辑的理解和应用
根据空(1)所在语句的注释,明确是对函数usrSort进行调用。usrSort的原型声明为“void usrSort(int n,int a[]”,调用时第一个参数为一般的传值调用,实参需给出需要排序的数组元素个数,为10个,第二个参数是数组参数,需要将数组空间的首地址作为实参,用数组名或下标为0的数组元素取地址都可以,因此空(1)应填入“usrSort(10,a)”或其等效形式。
空(2)所在语句是调用memset对申请的存储区域进行初始化。根据注释,要求将temp_arr指向的内存区域清零,根据声明memset时的形参要求,结合调用malloc的实参值N
*
sizeof(int),可知函数调用为memset(temp_arr 0,N
*
sizeof(int))。
空(3)所在的循环语句遍历数组a[]的所有元素,将元素a
作为temp_arr的下标,从而使得temp_arr[a
]表示了a
表示的值在数组a中出现的次数。
在数组a中安排最后排序的元素时,for循环控制需要排列的元素i(即出现个数大于0者),根据注释“cnt表示i在数组a中的出现次数”,可知空(4)处应设置cnt的初始值,为“temp_arr
”。接下来通过while循环,根据i出现的次数将i逐个放入数组中,每放入1个i,cnt自减,相应地,k需要自增,以给出下一个i要放入的数组元素,因此空(5)处应填入“k++”或其等效形式。
转载请注明原文地址:https://kaotiyun.com/show/y2jZ777K
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
计算机使用了一段时间后,系统磁盘空间不足,系统启动时间变长,系统响应延迟,应用程序运行缓慢,此时,需要对系统进行优化。(28)________________不属于系统优化工作。
若在Excel的A1单元格中输入函数“=SUM(1,12,false)”,按回车键后,则A1单元格中显示的值为________。
在Excel中,设单元格A1中的值为80,B1中的值为35,若在C1单元格中输入函数“=IF(AND(A1>=60,B1>=60),“不及格”,“补考”)”,按回车键后,C1单元格中的值为()。
综合布线系统由6个子系统组成,将图1-1中(1)~(6)处空缺子系统的名称填写在答题纸对应的解答栏内。为满足公司要求,通常选用什么类型的信息插座?
综合布线系统由6个子系统组成,将图1-1中(1)~(6)处空缺子系统的名称填写在答题纸对应的解答栏内。考虑性能与价格因素,图1-1中(1)、(2)和(4)中各应采用什么传输介质?
阅读以下说明,回答问题1至问题4。说明某公司A楼高40层,每层高3.3米,同一楼层内任意两个房间最远传输距离不超过90米,A楼和B楼之间距离为500米,需在整个大楼进行综合布线,结构如图1-1所示。为满足公司业务发展的需要,要求为楼内客户机提供数
资源记录文件位于/var/named目录下。这个目录是在以上的(1)文件中定义的。从备选选项中选择(6)~(10)处的解答。在问题4的named.abc.net文件中,出现了5种类型的记录。其中SOA是(6),NS是(7),MX是(8),A是
随机试题
中国新民主主义革命的开端是()
Thesalesmanapproachedthehousevery______becausetherewasadogatthegate.
固本止崩汤用于治疗
某市制定了峰谷分时电价方案。峰时电价为原电价的110%,谷时电价为原电价的八折。小静家六月用电400度,其中峰时用电210度,谷时用电190度,实行峰谷分时电价调整方案后小静家用电成本为调整前的多少?
施工单位未按照民用建筑节能强制性标准进行施工的,由县级以上地方人民政府建设主管部门责令改正,处民用建筑项目合同价款()的罚款。
我国某进出口公司(甲方)与新加坡(乙方)某公司签订一出口合同,合同中订明,甲方向乙方出售5000件衬衫,于2004年4月10日在上海装船,途经香港运往新加坡。在签订合同时甲方得知乙方还要将该批货物从新加坡运往智利。根据上述情况填写报关单时,以下哪几
使用投资报酬率考核投资中心的业绩,便于不同部门之间的比较,但可能会引起部门经理投资决策的次优化。()
非居民个人约翰,2019年从我国取得收入构成:受雇A公司,月薪14500元;同时在B公司兼职讲课,每次获得报酬850元,每月讲课4次。此外,约翰5岁的女儿在中国某语言学校学习汉语,不考虑其他事项,以下说法正确的是()。
在数据仓库环境中,粒度是一个重要的设计问题。粒度越_______,细节程度越高,能回答的查询就越多,数据量就比较大。
Whereistheconversationtakingplace?
最新回复
(
0
)