第 1 頁:程序填空題 |
第 2 頁:程序改錯題 |
第 3 頁:程序設計題 |
第 4 頁:參考答案 |
上機考試試題答案與解析
一、程序填空題
【1】M-1【2】bb[n++]=arr[i]【3】i,bb[i]
【解析】由整個for循環(huán)可知,變量i為數組art的下標,題目中要求取出前一個元素比后一個元素小的元素,所以只需要判斷前M-1個元素即可。因此,【1】處填“M-l”;如果第i個元素比第i+1個元素小,將第i個元素放入數組bb中,因此,【2】處填“bb[n++]=arr[i]”。最后,要輸出數組bb中的每一個元素。因此,【3】處填“i,bb[i]”。
二、程序改錯題
(1)錯誤:int proc(void)
正確:void proc(void)
(2)錯誤:printf("%f",m[j]%5);
正確:printf("%f",m[j]/5);
【解析】由主函數中的函數調用可知,函數proc()沒有返回值。因此,“int proc(void)”應改為“void proc(void)”。題目中要求使數組中元素的值縮小到1/5,而不是對5取余。因此,“printf("%f",m[j]%5);”應改為“printf("%f",m[j]/5);”。
三、程序設計題
void proc(STREC a[])
{
int i,j;
STREC t:
for(i=1;i 排序
for(j=0;j if(a[j].s 的記錄,高分在前
{t=a[j];a[j]=a[j+1];a[j+1]=t;}
}
【解析】要按分數的高低排列學生的記錄,可以使用冒泡排序法。將每一個學生的成績與其他學生的成績相比較,對不符合要求的記錄交換位置。
相關推薦:
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |