第 1 頁:試題 |
第 4 頁:參考答案 |
(36)D
【解析】 本題考查鏈表的數(shù)據結構,必須利用指針變量才能實現(xiàn),即一個結點中應包含一個指針變量,用它存放下一結點的地址。
(37)B
【解析】 以"wt"方式寫入的是字符文件,轉義字符'\n'被看作兩個字符來處理。而"wb"方式寫入的是二進制文件,轉義字符'\n'是一個字符。
(38)A
【解析】 本題考查的是位運算的知識,對于任何二進制數(shù),和1進行異或運算會讓其取反,而和0進行異或運算不會產生任何變化。
(39)C
【解析】 本題主要考查的是用二維數(shù)組首地址和下標來引用二維數(shù)組元素的方法。通過分析可知,程序中的雙重循環(huán)定義了一個如下的二維數(shù)組:
0 1 2
2 3 4
4 5 6
由于數(shù)組的下標是從0開始的,所以二維數(shù)組元素a[i][j]表示的是二維數(shù)組a的第i+1行、第j+1列對應位置的元素。
(40)A
【解析】 函數(shù)的參數(shù)不僅可以是整型、實型、字符型等數(shù)據,還可以是指針型。它的作用是將一個變量的地址傳遞到另一個函數(shù)中。當數(shù)組名作參數(shù)時,如果形參數(shù)組中的各元素的值發(fā)生變化,實參數(shù)組元素的值也將隨之發(fā)生變化。
二、選擇題
(1)【1】調試
【解析】 軟件測試的目標是在精心控制的環(huán)境下執(zhí)行程序,以發(fā)現(xiàn)程序中的錯誤,給出程序可靠性的鑒定;調試也稱排錯,它是一個與測試既有聯(lián)系又有區(qū)別的概念。具體來說,測試的目的是暴露錯誤,評價程序的可靠性,而調試的目的是發(fā)現(xiàn)錯誤的位置,并改正錯誤。
(2)【2】19
【解析】 在任意一棵二叉樹中,度為0的結點(即葉子結點)總是比度為2的結點多一個。
(3)【3】 上溢
【解析】 入隊運算是指在循環(huán)隊列的隊尾加入一個新元素。這個運算有兩個基本操作:首先將隊尾指針進一(即rear=rear+1),并當rear=m+1時,置rear=1;然后將新元素插入隊尾指針指向的位置。當循環(huán)隊列非空(s=1)且隊尾指針等于隊頭指針時,說明循環(huán)隊列已滿,不能進行入隊運算,這種情況稱為"上溢"。
(4)【4】 關系
【解析】 在關系模型中,把數(shù)據看成一個二維表,每一個二維表稱為一個關系。表中的每一列稱為一個屬性,相當于記錄中的一個數(shù)據項,對屬性的命名稱為屬性名;表中的一行稱為一個元組,相當于記錄值。
(5)【5】 操作系統(tǒng)或OS
【解析】 數(shù)據庫管理系統(tǒng)是數(shù)據庫的機構,它是一種系統(tǒng)軟件,負責數(shù)據庫中的數(shù)據組織、數(shù)據操縱、數(shù)據維護、控制及保護和數(shù)據服務。位于用戶和操作系統(tǒng)之間。
(6)【6】 a
【解析】 'z'的ASCII碼值為122,經過c-25運算后,得97,以字符形式輸出是a。
(7)【7】 1,0
【解析】 與運算兩邊的語句必須同時為真時,結果才為真。當執(zhí)行完if((++a<0)&&!(b--<=0))時,a,b的值已經發(fā)生了變化。
(8)【8】 1
3
5
【解析】 本題考查了for循環(huán)語句的使用,break語句用在本題中是結束for循環(huán)直接跳出循環(huán)體外。當i=1時,因為if語句條件不滿足,所以直接執(zhí)行printf("%d\n",i++);輸出1,同時i自加1;執(zhí)行第二次for循環(huán)時,i=3;同樣的if語句條件不滿足,所以直接執(zhí)行printf("%d\n",i++);輸出3,同時i自加1;執(zhí)行第三次for循環(huán)時,i=5,if語句條件滿足,所以執(zhí)行printf("%d\n",i),輸出5,然后break語句跳出了for循環(huán)。
(9)【9】 2
【10】 2 4 6 8
【解析】 在主函數(shù)中根據整型數(shù)組x[]的定義可知,x[1]的初值等于2。在for循環(huán)語句中,當i=0時,p[0]=&x[1],p[0][0]=2; 當i=1時,p[1]=&x[3],p[1][0]=4;當i=2時,p[2]=&x[5],p[2][0]=6;當i=3時,p[3]=&x[7],p[3][0]=8,所以程序輸出的結果為2、4、6、8。
(10)【11】 35
【解析】 函數(shù)swap(int *a,int *b)的功能是實現(xiàn)*a和*b中兩個數(shù)據的交換,在主函數(shù)中調用swap(p,q)后,形參指針變量a和b分別指向i和j,在swap(int *a,int *b)執(zhí)行完后,指針變量a和b分別指向j和i,而指針變量p,q所指向變量的值沒有發(fā)生變化,所以輸出結果為35。
(11)【12】 BCD
CD
D
【解析】 本題考查指向字符串的指針的運算方法。指針變量p首先指向字符串中的第一個字符A,執(zhí)行p=s+1后,p指向字符串中的第二個字符B,然后輸出值"BCD"并換行,依次執(zhí)行循環(huán)語句。
(12)【13】 9
【解析】 本題考查函數(shù)的綜合知識。首先,我們可以利用強制轉換類型轉換運算符,將一個表達式轉換成所需類型。如:(double)a是將a轉換成double類型;(int)(x+y)是將x+y的值轉換成整型。
本題可按部就班地逐步運算:
fun((int)fun(a+c,b),a-c)
fun((int)fun(10,5),2-8)
fun((int)15.000000,-6)
fun(15,-6)
9
(13)【14】 struct aa *lhead,*rchild;
【解析】 結構體對鏈表的定義。
(14)【15】 fseek(文件指針,位移量,起始點)
【解析】 本題考查函數(shù)fseek的用法。fseek函數(shù)的調用形式為:
fseek(文件指針,位移量,起始點)
"起始點"用0,1或2代替,其中,0代表"文件開始";1為"當前位置";2為"文件末尾"。"位移量"指以"起始點"為基點,向前移動的字節(jié)數(shù)。ANSI C和大多數(shù)C版本要求位移量是long型數(shù)據,這樣當文件的長度大于64k時不致出現(xiàn)問題。ANSI C標準規(guī)定在數(shù)字的末尾加一個字母L,就表示long型。
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |