C++算法優(yōu)化的試題及答案_第1頁
C++算法優(yōu)化的試題及答案_第2頁
C++算法優(yōu)化的試題及答案_第3頁
C++算法優(yōu)化的試題及答案_第4頁
C++算法優(yōu)化的試題及答案_第5頁
已閱讀5頁,還剩18頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

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

文檔簡介

C++算法優(yōu)化的試題及答案姓名:____________________

一、單項(xiàng)選擇題(每題2分,共10題)

1.下列哪個不是C++中常用的排序算法?

A.冒泡排序

B.快速排序

C.歸并排序

D.選擇排序

2.下面哪個函數(shù)可以用于計算兩個整數(shù)的最大公約數(shù)?

A.gcd

B.max

C.min

D.abs

3.關(guān)于C++中的動態(tài)內(nèi)存分配,以下說法錯誤的是:

A.使用new操作符可以動態(tài)分配內(nèi)存

B.使用delete操作符可以釋放動態(tài)分配的內(nèi)存

C.使用new[]操作符可以動態(tài)分配數(shù)組內(nèi)存

D.使用delete[]操作符可以釋放動態(tài)分配的數(shù)組內(nèi)存,但不需要指定大小

4.下面哪個選項(xiàng)是C++中用于實(shí)現(xiàn)遞歸的函數(shù)?

A.loop

B.recurse

C.return

D.go

5.下面哪個是C++中用于實(shí)現(xiàn)選擇排序的代碼段?

A.

```

voidselectionSort(intarr[],intn){

for(inti=0;i<n-1;i++){

intminIndex=i;

for(intj=i+1;j<n;j++){

if(arr[j]<arr[minIndex]){

minIndex=j;

}

}

inttemp=arr[minIndex];

arr[minIndex]=arr[i];

arr[i]=temp;

}

}

```

B.

```

voidselectionSort(intarr[],intn){

for(inti=0;i<n;i++){

intminIndex=i;

for(intj=i+1;j<n;j++){

if(arr[j]<arr[minIndex]){

minIndex=j;

}

}

inttemp=arr[minIndex];

arr[minIndex]=arr[i];

arr[i]=temp;

}

}

```

C.

```

voidselectionSort(intarr[],intn){

for(inti=0;i<n-1;i++){

intminIndex=i;

for(intj=i+1;j<n;j++){

if(arr[j]<arr[minIndex]){

minIndex=j;

}

}

inttemp=arr[minIndex];

arr[minIndex]=arr[i];

arr[i]=temp;

}

}

```

D.

```

voidselectionSort(intarr[],intn){

for(inti=0;i<n;i++){

intminIndex=i;

for(intj=i+1;j<n;j++){

if(arr[j]<arr[minIndex]){

minIndex=j;

}

}

inttemp=arr[minIndex];

arr[minIndex]=arr[i];

arr[i]=temp;

}

}

```

6.下面哪個是C++中用于實(shí)現(xiàn)二分查找的代碼段?

A.

```

intbinarySearch(intarr[],intl,intr,intx){

while(l<=r){

intm=l+(r-l)/2;

if(arr[m]==x){

returnm;

}

if(arr[m]<x){

l=m+1;

}else{

r=m-1;

}

}

return-1;

}

```

B.

```

intbinarySearch(intarr[],intl,intr,intx){

while(l<=r){

intm=l+(r-l)/2;

if(arr[m]==x){

returnm;

}

if(arr[m]<x){

l=m-1;

}else{

r=m+1;

}

}

return-1;

}

```

C.

```

intbinarySearch(intarr[],intl,intr,intx){

while(l<=r){

intm=l+(r-l)/2;

if(arr[m]==x){

returnm;

}

if(arr[m]<x){

l=m+1;

}else{

r=m-1;

}

}

return-1;

}

```

D.

```

intbinarySearch(intarr[],intl,intr,intx){

while(l<=r){

intm=l+(r-l)/2;

if(arr[m]==x){

returnm;

}

if(arr[m]<x){

l=m+1;

}else{

r=m-1;

}

}

return-1;

}

```

7.下面哪個是C++中用于實(shí)現(xiàn)冒泡排序的代碼段?

A.

```

voidbubbleSort(intarr[],intn){

for(inti=0;i<n-1;i++){

for(intj=0;j<n-i-1;j++){

if(arr[j]>arr[j+1]){

inttemp=arr[j];

arr[j]=arr[j+1];

arr[j+1]=temp;

}

}

}

}

```

B.

```

voidbubbleSort(intarr[],intn){

for(inti=0;i<n;i++){

for(intj=0;j<n-i-1;j++){

if(arr[j]>arr[j+1]){

inttemp=arr[j];

arr[j]=arr[j+1];

arr[j+1]=temp;

}

}

}

}

```

C.

```

voidbubbleSort(intarr[],intn){

for(inti=0;i<n-1;i++){

for(intj=0;j<n-i-1;j++){

if(arr[j]>arr[j+1]){

inttemp=arr[j];

arr[j]=arr[j+1];

arr[j+1]=temp;

}

}

}

}

```

D.

```

voidbubbleSort(intarr[],intn){

for(inti=0;i<n;i++){

for(intj=0;j<n-i-1;j++){

if(arr[j]>arr[j+1]){

inttemp=arr[j];

arr[j]=arr[j+1];

arr[j+1]=temp;

}

}

}

}

```

8.下面哪個是C++中用于實(shí)現(xiàn)歸并排序的代碼段?

A.

```

voidmergeSort(intarr[],intl,intr){

if(l<r){

intm=l+(r-l)/2;

mergeSort(arr,l,m);

mergeSort(arr,m+1,r);

merge(arr,l,m,r);

}

}

```

B.

```

voidmergeSort(intarr[],intl,intr){

if(l<r){

intm=l+(r-l)/2;

mergeSort(arr,l,m);

mergeSort(arr,m+1,r);

merge(arr,l,m,r);

}

}

```

C.

```

voidmergeSort(intarr[],intl,intr){

if(l<r){

intm=l+(r-l)/2;

mergeSort(arr,l,m);

mergeSort(arr,m+1,r);

merge(arr,l,m,r);

}

}

```

D.

```

voidmergeSort(intarr[],intl,intr){

if(l<r){

intm=l+(r-l)/2;

mergeSort(arr,l,m);

mergeSort(arr,m+1,r);

merge(arr,l,m,r);

}

}

```

9.下面哪個是C++中用于實(shí)現(xiàn)插入排序的代碼段?

A.

```

voidinsertionSort(intarr[],intn){

for(inti=1;i<n;i++){

intkey=arr[i];

intj=i-1;

while(j>=0&&arr[j]>key){

arr[j+1]=arr[j];

j=j-1;

}

arr[j+1]=key;

}

}

```

B.

```

voidinsertionSort(intarr[],intn){

for(inti=1;i<n;i++){

intkey=arr[i];

intj=i-1;

while(j>=0&&arr[j]<key){

arr[j+1]=arr[j];

j=j-1;

}

arr[j+1]=key;

}

}

```

C.

```

voidinsertionSort(intarr[],intn){

for(inti=1;i<n;i++){

intkey=arr[i];

intj=i-1;

while(j>=0&&arr[j]>key){

arr[j+1]=arr[j];

j=j-1;

}

arr[j+1]=key;

}

}

```

D.

```

voidinsertionSort(intarr[],intn){

for(inti=1;i<n;i++){

intkey=arr[i];

intj=i-1;

while(j>=0&&arr[j]<key){

arr[j+1]=arr[j];

j=j-1;

}

arr[j+1]=key;

}

}

```

10.下面哪個是C++中用于實(shí)現(xiàn)希爾排序的代碼段?

A.

```

voidshellSort(intarr[],intn){

for(intgap=n/2;gap>0;gap/=2){

for(inti=gap;i<n;i+=1){

inttemp=arr[i];

intj;

for(j=i;j>=gap&&arr[j-gap]>temp;j-=gap){

arr[j]=arr[j-gap];

}

arr[j]=temp;

}

}

}

```

B.

```

voidshellSort(intarr[],intn){

for(intgap=n/2;gap>0;gap/=2){

for(inti=gap;i<n;i+=1){

inttemp=arr[i];

intj;

for(j=i;j>=gap&&arr[j-gap]<temp;j-=gap){

arr[j]=arr[j-gap];

}

arr[j]=temp;

}

}

}

```

C.

```

voidshellSort(intarr[],intn){

for(intgap=n/2;gap>0;gap/=2){

for(inti=gap;i<n;i+=1){

inttemp=arr[i];

intj;

for(j=i;j>=gap&&arr[j-gap]>temp;j-=gap){

arr[j]=arr[j-gap];

}

arr[j]=temp;

}

}

}

```

D.

```

voidshellSort(intarr[],intn){

for(intgap=n/2;gap>0;gap/=2){

for(inti=gap;i<n;i+=1){

inttemp=arr[i];

intj;

for(j=i;j>=gap&&arr[j-gap]<temp;j-=gap){

arr[j]=arr[j-gap];

}

arr[j]=temp;

}

}

}

```

二、多項(xiàng)選擇題(每題3分,共10題)

1.下列哪些是C++中常用的數(shù)據(jù)結(jié)構(gòu)?

A.隊列

B.鏈表

C.棧

D.數(shù)組

2.以下哪些是C++中用于處理文件輸入輸出的操作?

A.cin

B.cout

C.ifstream

D.ofstream

3.在C++中,以下哪些是合法的標(biāo)識符?

A.myVariable

B.2myVariable

C.my_variable

D._myVariable

4.下面哪些是C++中用于處理異常的語句?

A.try

B.catch

C.throw

D.finally

5.以下哪些是C++中用于控制程序的流程的語句?

A.if

B.switch

C.while

D.return

6.下列哪些是C++中用于處理字符串的函數(shù)?

A.strlen

B.strcpy

C.strcat

D.strstr

7.下面哪些是C++中用于實(shí)現(xiàn)遞歸的函數(shù)?

A.loop

B.recurse

C.return

D.go

8.以下哪些是C++中用于實(shí)現(xiàn)動態(tài)內(nèi)存分配的函數(shù)?

A.new

B.delete

C.malloc

D.free

9.下面哪些是C++中用于實(shí)現(xiàn)數(shù)組和字符串操作的關(guān)鍵字?

A.[]

B.->

C..(點(diǎn)操作符)

D.::(作用域解析操作符)

10.以下哪些是C++中用于處理數(shù)據(jù)的運(yùn)算符?

A.+

B.*

C.%

D.&

三、判斷題(每題2分,共10題)

1.C++中,所有變量都必須在定義后才能使用。()

2.在C++中,結(jié)構(gòu)體和類是相同的概念,都可以包含數(shù)據(jù)和函數(shù)。()

3.C++中的函數(shù)必須返回值,即使不返回任何值也必須指定返回類型為void。()

4.在C++中,引用是變量的別名,對引用的修改會直接影響原變量的值。()

5.C++中的數(shù)組是靜態(tài)分配的,不能在運(yùn)行時動態(tài)改變大小。()

6.在C++中,構(gòu)造函數(shù)和析構(gòu)函數(shù)的名字必須與類名相同,并且沒有返回類型。()

7.C++中的模板可以用來創(chuàng)建泛型代碼,可以接受任何類型的數(shù)據(jù)。()

8.在C++中,運(yùn)算符重載允許對自定義類型進(jìn)行擴(kuò)展,使其支持新的運(yùn)算符。()

9.C++中的異常處理機(jī)制可以捕獲和處理所有類型的錯誤。()

10.在C++中,虛函數(shù)可以保證在派生類中正確調(diào)用基類的函數(shù),即使派生類沒有重寫該函數(shù)。()

四、簡答題(每題5分,共6題)

1.簡述C

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論