湖北科技學(xué)院《C程序設(shè)計(jì)》2021-2022學(xué)年第一學(xué)期期末試卷_第1頁(yè)
湖北科技學(xué)院《C程序設(shè)計(jì)》2021-2022學(xué)年第一學(xué)期期末試卷_第2頁(yè)
湖北科技學(xué)院《C程序設(shè)計(jì)》2021-2022學(xué)年第一學(xué)期期末試卷_第3頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

站名:站名:年級(jí)專(zhuān)業(yè):姓名:學(xué)號(hào):凡年級(jí)專(zhuān)業(yè)、姓名、學(xué)號(hào)錯(cuò)寫(xiě)、漏寫(xiě)或字跡不清者,成績(jī)按零分記。…………密………………封………………線…………第1頁(yè),共1頁(yè)湖北科技學(xué)院《C程序設(shè)計(jì)》

2021-2022學(xué)年第一學(xué)期期末試卷題號(hào)一二三四總分得分批閱人一、單選題(本大題共15個(gè)小題,每小題1分,共15分.在每小題給出的四個(gè)選項(xiàng)中,只有一項(xiàng)是符合題目要求的.)1、在C語(yǔ)言中,對(duì)于指針和數(shù)組的關(guān)系,假設(shè)有一個(gè)數(shù)組

intarr[10]

,同時(shí)有一個(gè)指針

int*ptr=arr;

,那么

ptr+2

指向的是什么?()A.

arr[2]

B.

arr[3]

C.

arr[1]

D.不確定2、若有定義:inta=3,b=2,c=1;則表達(dá)式a-b>c的值是()A.0B.1C.2D.33、C語(yǔ)言中的輸入輸出函數(shù)

scanf

printf

用于與用戶進(jìn)行交互。假設(shè)要從用戶輸入中讀取一個(gè)整數(shù)和一個(gè)浮點(diǎn)數(shù),以下關(guān)于輸入輸出的描述,哪一項(xiàng)是錯(cuò)誤的?()A.使用

scanf("%d%f",&num1,&num2);

可以實(shí)現(xiàn)B.輸入的數(shù)據(jù)格式必須與

scanf

中的格式控制字符串匹配,否則可能導(dǎo)致錯(cuò)誤C.

printf

函數(shù)可以使用不同的格式控制符來(lái)輸出各種類(lèi)型的數(shù)據(jù)D.

scanf

函數(shù)會(huì)自動(dòng)處理輸入數(shù)據(jù)中的空格和換行符4、以下C語(yǔ)言代碼段的輸出結(jié)果是多少?

inti;for(i=0;i<10;i++){if(i%2==0)continue;printf("%d",i);}

()A.13579B.02468C.123456789D.01234567895、在C語(yǔ)言中,關(guān)于動(dòng)態(tài)內(nèi)存分配,使用

malloc

函數(shù)分配內(nèi)存后,如果不再使用,應(yīng)該使用哪個(gè)函數(shù)釋放內(nèi)存?()A.

free

B.

delete

C.

release

D.不需要釋放6、若有定義:inta[3][3]={{1,2,3},{4,5,6},{7,8,9}};,則((a+1)+2)的值是()A.5B.6C.8D.97、若有定義:inta=10,b=20;則以下表達(dá)式的值為20的是()A.a>b?a:bB.a<b?a:bC.a==b?a:bD.a!=b?a:b8、若有定義:floatx=3.5;intz=8;,則表達(dá)式x+z%3的值為()A.4.5B.5.5C.6.5D.7.59、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ò)多10、在C語(yǔ)言中,關(guān)于指針和數(shù)組的關(guān)系,以下代碼:

intarr[]={1,2,3,4,5};int*ptr=arr;

,以下描述正確的是:()A.

ptr+2

指向數(shù)組的第3個(gè)元素B.

*(ptr+2)

的值為2C.

ptr

arr

的地址一定不同D.對(duì)

ptr

進(jìn)行加減運(yùn)算會(huì)導(dǎo)致程序錯(cuò)誤11、C語(yǔ)言中的

const

關(guān)鍵字用于修飾變量,使其具有只讀屬性。假設(shè)我們有

constintnum=5;

,以下關(guān)于對(duì)

num

變量的操作,哪一個(gè)是合法的?()A.可以通過(guò)指針修改

num

的值B.可以直接修改

num

的值C.既不能直接修改,也不能通過(guò)指針修改

num

的值D.以上都不對(duì)12、在C語(yǔ)言的結(jié)構(gòu)體使用中,假設(shè)我們定義了一個(gè)結(jié)構(gòu)體

structStudent{intid;charname[20];floatscore;};

,并且創(chuàng)建了一個(gè)結(jié)構(gòu)體變量。如果要將這個(gè)結(jié)構(gòu)體變量作為函數(shù)參數(shù)傳遞,以下哪種方式效率更高并且能避免不必要的內(nèi)存復(fù)制?()A.按值傳遞B.按指針傳遞C.按引用傳遞(C語(yǔ)言中無(wú)引用)D.以上效率相同13、若有定義:charstr[]="hello";則sizeof(str)的值是()A.5B.6C.10D.不確定14、C語(yǔ)言中,對(duì)于以下的循環(huán)語(yǔ)句

for(inti=0;i<5;i++)

,循環(huán)體執(zhí)行的次數(shù)是多少?()A.4次B.5次C.6次D.不確定15、在C語(yǔ)言中,動(dòng)態(tài)內(nèi)存分配是一項(xiàng)靈活但需要謹(jǐn)慎使用的操作。假設(shè)有如下代碼

int*ptr=(int*)malloc(sizeof(int)*10);

,以下對(duì)于動(dòng)態(tài)內(nèi)存分配的描述,哪一項(xiàng)是不準(zhǔn)確的?()A.

malloc

函數(shù)返回的是一個(gè)指向分配內(nèi)存的起始地址的指針,如果分配失敗會(huì)返回

NULL

B.分配的內(nèi)存空間是連續(xù)的,并且其大小由指定的字節(jié)數(shù)決定C.動(dòng)態(tài)分配的內(nèi)存空間在使用完畢后,必須使用

free

函數(shù)釋放,否則會(huì)導(dǎo)致內(nèi)存泄漏D.可以使用

realloc

函數(shù)直接修改已經(jīng)分配的內(nèi)存空間的大小,而不需要重新分配二、判斷題(本大題共10小題,每小題2分,共20分.有多個(gè)選項(xiàng)是符合題目要求的.)1、C語(yǔ)言中,getchar函數(shù)用于從鍵盤(pán)輸入一個(gè)字符。()2、在C語(yǔ)言中,

#if

、

#else

#endif

等預(yù)處理指令可以根據(jù)條件決定哪些代碼被編譯,哪些代碼被忽略。()3、C語(yǔ)言中的文件操作通過(guò)一系列的標(biāo)準(zhǔn)庫(kù)函數(shù)來(lái)實(shí)現(xiàn),包括文件的打開(kāi)、讀寫(xiě)、關(guān)閉等操作,文件可以以文本模式或二進(jìn)制模式進(jìn)行處理。()4、在C語(yǔ)言中,

fprintf

fscanf

函數(shù)用于對(duì)文件進(jìn)行格式化的讀寫(xiě)操作,其用法與

printf

scanf

類(lèi)似,但需要指定文件指針。()5、在C語(yǔ)言中,使用sprintf函數(shù)可以將數(shù)據(jù)按照指定格式輸出到字符串中。()6、C語(yǔ)言中,函數(shù)調(diào)用時(shí),形參的值改變會(huì)影響實(shí)參的值。()7、C語(yǔ)言中的static關(guān)鍵字,用于修飾局部變量時(shí),該變量的值在函數(shù)調(diào)用結(jié)束后不會(huì)被銷(xiāo)毀,下次調(diào)用函數(shù)時(shí)仍然保留上次的值。()8、C語(yǔ)言中的聯(lián)合體(union)的成員變量可以有不同的存儲(chǔ)類(lèi)型。()9、在C語(yǔ)言中,使用access函數(shù)可以檢查文件的訪問(wèn)權(quán)限。()10、在C語(yǔ)言中,使用指針可以實(shí)現(xiàn)對(duì)二維數(shù)組的訪問(wèn)和操作。()三、論述題(本大題共5個(gè)小題,共25分)1、(本題5分)請(qǐng)深入探討C語(yǔ)言中如何使用指針和結(jié)構(gòu)體實(shí)現(xiàn)一個(gè)簡(jiǎn)單的決策樹(shù)算法,并分析決策樹(shù)算法的優(yōu)缺點(diǎn)。2、(本題5分)探討C語(yǔ)言中如何利用函數(shù)指針實(shí)現(xiàn)函數(shù)的多態(tài)性,舉例說(shuō)明其應(yīng)用場(chǎng)景。3、(本題5分)論述C語(yǔ)言中如何使用指針實(shí)現(xiàn)字符串的查找特定字符操作。4、(本題5分)論述C語(yǔ)言中如何實(shí)現(xiàn)索引堆數(shù)據(jù)結(jié)構(gòu),解釋其用途和操作。5、(本題5分)論述C語(yǔ)言中如何使用動(dòng)態(tài)內(nèi)存分配和指針實(shí)現(xiàn)一個(gè)字符串的旋轉(zhuǎn)操作,將字符串的前若干字符移到末尾。四、編程題(本大題共4個(gè)小題,共40分)1、(本題10分)設(shè)計(jì)一個(gè)C語(yǔ)言程序,用戶輸入一個(gè)整數(shù)n,程序計(jì)算并輸出1到n之間所有數(shù)的各位數(shù)

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論