版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
學(xué)校________________班級(jí)____________姓名____________考場(chǎng)____________準(zhǔn)考證號(hào)學(xué)校________________班級(jí)____________姓名____________考場(chǎng)____________準(zhǔn)考證號(hào)…………密…………封…………線…………內(nèi)…………不…………要…………答…………題…………第2頁(yè),共2頁(yè)許昌學(xué)院《C語(yǔ)言程序設(shè)計(jì)》
2021-2022學(xué)年第一學(xué)期期末試卷題號(hào)一二三四總分得分批閱人一、單選題(本大題共25個(gè)小題,每小題1分,共25分.在每小題給出的四個(gè)選項(xiàng)中,只有一項(xiàng)是符合題目要求的.)1、C語(yǔ)言中,若有定義
enumdays{MON,TUE,WED,THU,FRI,SAT,SUN};
,那么
enumdaystoday=TUE;
之后,執(zhí)行
today++;
,
today
的值會(huì)變成多少?()A.WEDB.不確定C.運(yùn)行時(shí)錯(cuò)誤D.以上都不對(duì)2、在C語(yǔ)言中,對(duì)于
void
類型的指針,以下關(guān)于它的使用和限制的描述,哪一個(gè)是正確的?()A.可以指向任何類型的變量B.不能進(jìn)行解引用操作C.可以進(jìn)行算術(shù)運(yùn)算D.以上都不對(duì)3、C語(yǔ)言中,關(guān)于動(dòng)態(tài)內(nèi)存分配,若使用
int*p=(int*)malloc(sizeof(int)*10);
,以下描述正確的是:()A.分配的內(nèi)存空間會(huì)自動(dòng)初始化為0B.如果內(nèi)存分配失敗,
malloc
函數(shù)返回
NULL
C.可以使用
free(p)
釋放部分已分配的內(nèi)存D.不需要釋放通過(guò)
malloc
分配的內(nèi)存,程序結(jié)束時(shí)會(huì)自動(dòng)釋放4、若有定義:inta[3][3]={{1,2,3},{4,5,6},{7,8,9}};,則((a+1)+2)的值是()A.5B.6C.8D.95、假設(shè)在C語(yǔ)言中有以下結(jié)構(gòu)體定義
structstudent{intid;charname[20];floatscore;};
,以下關(guān)于結(jié)構(gòu)體的描述,正確的是:()A.可以直接將一個(gè)結(jié)構(gòu)體變量賦值給另一個(gè)結(jié)構(gòu)體變量B.結(jié)構(gòu)體成員的訪問(wèn)可以使用
struct.student.id
的形式C.結(jié)構(gòu)體數(shù)組中的元素不能通過(guò)指針進(jìn)行訪問(wèn)D.結(jié)構(gòu)體變量所占的內(nèi)存空間是其各成員所占空間之和6、在C語(yǔ)言中,關(guān)于動(dòng)態(tài)內(nèi)存分配的錯(cuò)誤處理,假設(shè)使用
malloc
分配內(nèi)存,以下關(guān)于錯(cuò)誤處理的描述,哪一項(xiàng)是不正確的?()A.分配內(nèi)存失敗時(shí),
malloc
返回
NULL
,可以通過(guò)判斷是否為
NULL
來(lái)進(jìn)行錯(cuò)誤處理B.忽略對(duì)
malloc
返回值的檢查,可能導(dǎo)致程序崩潰C.即使內(nèi)存分配成功,也可能因?yàn)楹罄m(xù)的操作導(dǎo)致內(nèi)存訪問(wèn)錯(cuò)誤D.一旦內(nèi)存分配成功,就無(wú)需再擔(dān)心內(nèi)存相關(guān)的錯(cuò)誤7、若有定義:floata=3.14;則以下不能正確輸出a的值的語(yǔ)句是()A.printf("%f",a);B.printf("%d",a);C.printf("%lf",a);D.printf("%e",a);8、C語(yǔ)言中的指針數(shù)組是指針的一種特殊用法。假設(shè)有以下定義:
int*ptrArr[3];
,以下關(guān)于指針數(shù)組的描述,正確的是:()A.這是一個(gè)可以存儲(chǔ)3個(gè)整數(shù)的數(shù)組B.這是一個(gè)可以存儲(chǔ)3個(gè)指針的數(shù)組,每個(gè)指針指向一個(gè)整數(shù)C.這是一個(gè)錯(cuò)誤的定義,C語(yǔ)言中不允許這樣定義指針數(shù)組D.這是一個(gè)指針,指向一個(gè)包含3個(gè)整數(shù)的數(shù)組9、若有定義:inta=3,b=2,c=1;,則表達(dá)式a-b>c的值為()A.0B.1C.2D.-110、C語(yǔ)言中,關(guān)于遞歸函數(shù),假設(shè)有以下定義:
intfactorial(intn){if(n==0||n==1)return1;elsereturnn*factorial(n-1);}
,那么
factorial(5)
的值是多少?()A.5B.15C.120D.程序會(huì)出錯(cuò)11、有關(guān)C語(yǔ)言中的volatile關(guān)鍵字,以下陳述不正確的是()A.volatile關(guān)鍵字用于告訴編譯器,變量的值可能會(huì)被意外地改變,不要進(jìn)行優(yōu)化B.多線程環(huán)境中共享的變量通常應(yīng)該使用volatile關(guān)鍵字修飾C.使用volatile關(guān)鍵字修飾的變量,其讀寫(xiě)操作一定是原子性的D.硬件寄存器通常使用volatile關(guān)鍵字修飾12、若有定義:charc='A';,則以下表達(dá)式的值為66的是()A.c+1B.c++C.++cD.'B'13、C語(yǔ)言中的動(dòng)態(tài)內(nèi)存分配函數(shù)
malloc
和
free
用于在運(yùn)行時(shí)分配和釋放內(nèi)存。假設(shè)有以下代碼片段:
int*ptr=(int*)malloc(sizeof(int)*5);
,以下關(guān)于這段代碼的描述,正確的是:()A.如果內(nèi)存分配成功,
ptr
將指向一段連續(xù)的、可存儲(chǔ)5個(gè)整數(shù)的內(nèi)存空間B.分配的內(nèi)存會(huì)自動(dòng)初始化為0C.即使內(nèi)存分配失敗,
ptr
也不會(huì)為
NULL
,需要通過(guò)其他方式判斷分配是否成功D.使用完分配的內(nèi)存后,不需要使用
free(ptr)
釋放,操作系統(tǒng)會(huì)自動(dòng)回收14、C語(yǔ)言中的文件讀寫(xiě)模式有多種,如只讀、只寫(xiě)、讀寫(xiě)等。假設(shè)要以讀寫(xiě)方式打開(kāi)一個(gè)文件,以下關(guān)于文件模式的描述,哪一項(xiàng)是錯(cuò)誤的?()A.使用
fopen("file.txt","r+")
可以以讀寫(xiě)方式打開(kāi)一個(gè)文本文件B.在讀寫(xiě)模式下,可以同時(shí)進(jìn)行讀取和寫(xiě)入操作C.讀寫(xiě)模式下,文件指針的初始位置在文件開(kāi)頭D.以讀寫(xiě)模式打開(kāi)一個(gè)不存在的文件會(huì)導(dǎo)致錯(cuò)誤15、在C語(yǔ)言的存儲(chǔ)類別中,以下關(guān)于register變量的描述,不正確的是()A.register變量通常用于存儲(chǔ)頻繁使用的變量,以提高訪問(wèn)速度B.register變量的數(shù)量是有限制的,具體數(shù)量由編譯器決定C.可以對(duì)register變量取地址D.register變量不一定真的被存儲(chǔ)在寄存器中,取決于編譯器的優(yōu)化16、C語(yǔ)言中的函數(shù)可以遞歸調(diào)用自身。假設(shè)有以下遞歸函數(shù)定義:
intfactorial(intn){if(n==0||n==1)return1;elsereturnn*factorial(n-1);}
,調(diào)用
factorial(5)
,以下關(guān)于函數(shù)返回值的描述,正確的是:()A.5B.15C.120D.程序會(huì)產(chǎn)生運(yùn)行時(shí)錯(cuò)誤,因?yàn)檫f歸次數(shù)過(guò)多17、C語(yǔ)言中的條件編譯指令
#ifdef
和
#ifndef
常用于根據(jù)條件決定是否編譯某段代碼。假設(shè)我們定義了一個(gè)宏
DEBUG
,在代碼中使用
#ifdefDEBUG
和
#ifndefDEBUG
,以下關(guān)于它們的作用和效果的描述,哪一個(gè)是正確的?()A.
#ifdefDEBUG
:如果定義了
DEBUG
宏,則編譯后面的代碼;
#ifndefDEBUG
:如果沒(méi)有定義
DEBUG
宏,則編譯后面的代碼B.
#ifdefDEBUG
:如果沒(méi)有定義
DEBUG
宏,則編譯后面的代碼;
#ifndefDEBUG
:如果定義了
DEBUG
宏,則編譯后面的代碼C.兩者作用相同,都是根據(jù)是否定義了
DEBUG
宏來(lái)決定是否編譯后面的代碼D.以上都不對(duì)18、若有定義:chars[100];以下不能正確把字符串"HelloWorld"存入數(shù)組s的語(yǔ)句是()A.gets(s);B.scanf("%s",s);C.strcpy(s,"HelloWorld");D.strcat(s,"HelloWorld");19、若有定義:charstr[]="hello";則sizeof(str)的值是()A.5B.6C.10D.不確定20、在C語(yǔ)言中,指針數(shù)組和數(shù)組指針是不同的概念。假設(shè)定義了
int*ptr1[5];
和
int(*ptr2)[5];
,以下關(guān)于它們的描述,哪一項(xiàng)是錯(cuò)誤的?()A.
ptr1
是一個(gè)指針數(shù)組,每個(gè)元素都是一個(gè)指針B.
ptr2
是一個(gè)數(shù)組指針,指向一個(gè)包含5個(gè)整數(shù)的數(shù)組C.對(duì)
ptr1
和
ptr2
的賦值和使用方式是相同的D.可以通過(guò)
ptr2
來(lái)訪問(wèn)數(shù)組中的元素21、在C語(yǔ)言的鏈表操作中,假設(shè)我們有一個(gè)簡(jiǎn)單的單向鏈表,每個(gè)節(jié)點(diǎn)包含一個(gè)整數(shù)數(shù)據(jù)和一個(gè)指向下一個(gè)節(jié)點(diǎn)的指針。當(dāng)要?jiǎng)h除鏈表中的一個(gè)節(jié)點(diǎn)時(shí),需要注意哪些問(wèn)題?()A.只需要修改要?jiǎng)h除節(jié)點(diǎn)的指針B.要修改前一個(gè)節(jié)點(diǎn)的指針指向刪除節(jié)點(diǎn)的下一個(gè)節(jié)點(diǎn)C.不需要做任何操作,系統(tǒng)會(huì)自動(dòng)處理D.以上都不對(duì)22、若有定義:intx=3,y=2;則表達(dá)式x=(y++)+x的值是()A.5B.6C.7D.823、在C語(yǔ)言中,若有函數(shù)定義
voidfun(inta[],intn)
,以下調(diào)用正確的是()A.
fun(10);
B.
fun({1,2,3},3);
C.
fun(1,2,3);
D.
fun(a,3);
(假設(shè)
inta[]={1,2,3};
)24、若有定義:inta=7;floatx=2.5,y=4.7;則表達(dá)式x+a%3*(int)(x+y)%2/4的值是()A.2.500000B.2.750000C.3.500000D.0.00000025、在C語(yǔ)言中,若有定義
charstr[20]="Hello";
,以下能正確將字符串
str
輸出的是()A.
printf("%s",&str);
B.
printf("%s",str);
C.
printf("%c",&str);
D.
printf("%c",str);
二、判斷題(本大題共10小題,每小題2分,共20分.有多個(gè)選項(xiàng)是符合題目要求的.)1、在C語(yǔ)言中,使用fflush函數(shù)可以強(qiáng)制將緩沖區(qū)中的數(shù)據(jù)寫(xiě)入文件。()2、C語(yǔ)言中的三目運(yùn)算符
?:
的結(jié)合性是從右向左。()3、在C語(yǔ)言中,使用strcpy函數(shù)復(fù)制字符串時(shí),目標(biāo)字符串的空間必須足夠大,否則會(huì)導(dǎo)致緩沖區(qū)溢出。()4、在C語(yǔ)言中,使用fscanf函數(shù)從文件中讀取數(shù)據(jù)時(shí),格式控制符必須與要讀取的數(shù)據(jù)類型相匹配。()5、定義一個(gè)函數(shù)
intmultiply(inta,intb){returna*b;}
,然后在主函數(shù)中調(diào)用
multiply(3,4)
,返回的值一定是12。()6、在C語(yǔ)言中,使用toupper函數(shù)可以將字符串中的所有小寫(xiě)字母轉(zhuǎn)換為大寫(xiě)字母。()7、在
switch
語(yǔ)句中,
case
后面的值必須是連續(xù)的整數(shù)。()8、在C語(yǔ)言中,預(yù)處理器指令#define可以用來(lái)定義常量和宏函數(shù)。()9、C語(yǔ)言中的預(yù)處理器指令可以實(shí)現(xiàn)條件包含,根據(jù)不同的條件決定是否包含某個(gè)頭文件。()10、C語(yǔ)言中的枚舉類型中的枚舉常量默認(rèn)從0開(kāi)始遞增。()三、編程題(本大題共5個(gè)小題,共25分)1、(本題5分)編寫(xiě)C程序,輸入一個(gè)字符串,判斷其中是否存在連續(xù)的三個(gè)相同字符。2、(本題5分)編寫(xiě)一個(gè)C語(yǔ)言程序,輸入一個(gè)整數(shù)數(shù)組,找出其中所有元素的方差(保留兩位小數(shù))并輸出。3、(本題5分)編寫(xiě)一個(gè)C語(yǔ)言程序,對(duì)一個(gè)鏈表進(jìn)行分組,每k個(gè)節(jié)點(diǎn)為一組進(jìn)行反轉(zhuǎn)。4、(本題5分)編寫(xiě)一個(gè)C語(yǔ)言程序,
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 酒店改造合同范例范例
- 戶外汽燈租賃合同范例
- 鋪位 租賃合同范例
- 快遞員合作合同范例
- 家具買(mǎi)賣(mài)貸款合同范例
- 市政材料供應(yīng)合同范例
- 含司機(jī)租車(chē)合同范例
- 鞋面批發(fā)采購(gòu)合同范例
- 藥品合同范例格式
- 裝修固定總價(jià)合同范例
- 2024-2025學(xué)年高二上學(xué)期期末數(shù)學(xué)試卷(提高篇)(含答案)
- 2025年安全生產(chǎn)目標(biāo)實(shí)施計(jì)劃
- 福建百校2025屆高三12月聯(lián)考?xì)v史試卷(含答案解析)
- 2024年山西省建筑安全員《B證》考試題庫(kù)及答案
- 2023年益陽(yáng)市安化縣招聘鄉(xiāng)鎮(zhèn)衛(wèi)生院護(hù)理人員筆試真題
- 《基于PLC的智能交通燈控制系統(tǒng)設(shè)計(jì)》10000字(論文)
- 首都經(jīng)濟(jì)貿(mào)易大學(xué)《微積分》2021-2022學(xué)年第一學(xué)期期末試卷
- 人音版音樂(lè)七年級(jí)上冊(cè)《父親的草原母親的河》課件
- 2024年度短視頻內(nèi)容創(chuàng)作服務(wù)合同3篇
- 介入治療并發(fā)癥
- 鑄牢中華民族共同體意識(shí)-形考任務(wù)1-國(guó)開(kāi)(NMG)-參考資料
評(píng)論
0/150
提交評(píng)論