刷题刷出新高度,偷偷领先!偷偷领先!偷偷领先! 关注我们,悄悄成为最优秀的自己!
a[i]<minimum,或a[i]<=minimum,或其等价形式 a[i]>maximum,或a[i]>=maximum,或其等价形式 0 b[k],或b[k]>0,或b[k]!=0,或其等价形式 k
本题考查C程序的基本语法和运算逻辑。
首先,应认真分析题目中的说明,然后确定代码结构和各变量的作用。
对于空(1)和空(2),所在的for语句的功能是求出数组a中的最小元素minimum和最大元素maximum。在设置了minimum和maximum的初始值后,空(1)处的判断条件是只要目前的元素a[i]小于minimum,就需要更新minimum,反之,空(2)处的判断条件是只要目前的元素a[i]大于maximum,就需要更新maximum。因此空(1)处应填入a[i]<minimum或其等价方式,空(2)处应填入a[i]>maximum或其等价方式。minimum和maximum的作用是要确定计数数组b的大小。
根据题目中的描述,序列中的每个元素a[i]都对应到计数数组b[]的一个元素b[k],对应方式为:k = a[i]-minimum,其中minimum是数组a中的最小元素。在计数时,一个数值出现一次,就在对应的b[k]中累加一次。
对于空(3),是为了从数组a中的第一个元素开始写入排序后的序列,因此应填入0。
空(4)所在的语句是通过循环控制"for(k=0; k<number;k++)",已经明确数组b的下标变化方式,而需要写入数组a的元素个数表示在b[k]中,所以应填入"b[k]>0"或其等价形式,表示还有元素未写入。
对于空(5),由于b[k]中记录的是元素k+minimum的出现次数,所以在将元素值恢复后再写回数组a时,应填入k,以得到正确的元素值。
让学习像火箭一样快速,微信扫码,获取考试解析、体验刷题服务,开启你的学习加速器!
