激情欧美日韩一区二区,浪货撅高贱屁股求主人调教视频,精品无码成人片一区二区98,国产高清av在线播放,色翁荡息又大又硬又粗视频

計算機二級模擬試題及答案

時(shí)間:2024-07-16 21:29:36 計算機等級 我要投稿

2016計算機二級模擬試題及答案

  計算機考試來(lái)啦!今天小編就給大家分享一些計算機二級考試的模擬試題,供大家參考~

2016計算機二級模擬試題及答案

  一、選擇題

  1算法的空間復雜度是指(  )。

  A.算法在執行過(guò)程中所需要的計算機存儲空間

  B.算法所處理的數據量

  C.算法程序中的語(yǔ)句或指令條數

  D.算法在執行過(guò)程中所需要的臨時(shí)工作單元數

  參考答案:A

  參考解析:一個(gè)算法的空間復雜度,一般是指執行這個(gè)算法所需要的內存空間。

  2每個(gè)C++程序中都必須有且僅有一個(gè)(  )。

  A.類(lèi)B.預處理命令C.主函數D.語(yǔ)句

  參考答案:C

  參考解析:每個(gè)C++程序中都要有且僅有一個(gè)主函數,該函數是程序的入口,而語(yǔ)句、預處理命令和函數及類(lèi)在程序中都可以有多個(gè)。

  3對長(cháng)度為n的線(xiàn)性表排序,在最壞情況下,比較次數不是n(n-1)/2的排序方法是(  )。

  A.快速排序B.冒泡排序C.直接插入排序D.堆排序

  參考答案:D

  參考解析:首先知道有哪些排序的方法及各種排序方法在最壞情況下需要比較的次數,冒泡排序n(n-1)/2、希爾排序0(n1.5)、簡(jiǎn)單選擇排序n(n-1)/2、堆排序O(nl0g2n)。

  4數據庫系統的三級模式不包括(  )。

  A.概念模式B.內模式C.外模式D.數據模式

  參考答案:D

  參考解析:數據庫三級模式包括:概念模式、內模式、外模式。

  5SQL語(yǔ)言又稱(chēng)為(  )。

  A.結構化定義語(yǔ)言

  B.結構化控制語(yǔ)言

  C.結構化查詢(xún)語(yǔ)苦

  D.結構化操縱語(yǔ)言

  參考答案:C

  參考解析:SQL語(yǔ)言的全稱(chēng)為StructuredQueryLanguage,它是一種介于關(guān)系代數與關(guān)系演算之間的結構化查詢(xún)語(yǔ)言,是一種面向數據庫的通用數據處理語(yǔ)言規范。它包含數據查詢(xún)語(yǔ)言、數據操縱語(yǔ)言、數據定義語(yǔ)言和數據控制語(yǔ)言四個(gè)部分。

  6數據處理的最小單位是(  )。

  A.數據B.數據元素C.數據項D.數據結構

  參考答案:C

  7假定MyClass為一個(gè)類(lèi),那么下列的函數說(shuō)明中,(  )為該類(lèi)的析構函數。

  A.void~MyClass();B.~MyC|ass(intn);C.MyClass();D.~MyClass();

  參考答案:D

  參考解析:C++語(yǔ)言中析構函數為符號“~”加類(lèi)名,且析構函數沒(méi)有返回值和參數,故前不加void關(guān)鍵字。所以正確的形式應該是~MyClass()。第7題 筆記記錄我的筆記(0) | 精選筆記(1)選擇筆記標簽:試題內容(1)答案解析(0)

  8有以下結構體說(shuō)明和變量的定義,且指針P指向變量a,指針q指向變量b。則不能把結點(diǎn)b連接到結點(diǎn)a之后的語(yǔ)句是(  )。

  structnode

  {chardata;

  structnode*next;

  }a,b,*p=&a,*q=&b;

  A.a.next=q;B.P.next=&b;C.p->next=&b;D.(*p).next=q;

  參考答案:B

  9若有表達式“(w)?(--x):(++y)”,則其中與w等價(jià)的表達式是(  )。

  A.w==1B.w==0C.W!=1D.W!=0

  參考答案:D

  參考解析:本題考查三目運算等。條件表達式的格式為a?b;c。它的含義是,當a為真時(shí),取b的值,否則取c的值。在C語(yǔ)言程序中“為真”即“不等于零”,“為假”即等于0。所以和w等價(jià)的表達式是w非零。

  10有如下函數模板聲明:

  template

  TMax(Ta,Tb){return(a>b)?a:b;}

  下列對函數模板Max(  )的調用中錯誤的是(  )。

  A.Max(3.5,4.5)B.Max(3.5,4)C.Max(35,4.5)D.Max(3.5,4)

  參考答案:B

  參考解析:本題考查函數模板的引用。引用模板函數和引用一般函數在語(yǔ)法形式上基本相同。需要注意的是,說(shuō)明一個(gè)函數模板后,當編譯系統發(fā)現有一個(gè)對應的函數調用時(shí),將根據實(shí)參中的類(lèi)型來(lái)確認是否調用函數模板中的對應形參。本題選項B中,編譯系統從第一個(gè)參數“3.5”獲得信息“double型數據”和從第二個(gè)參數獲得信息“int型數據”,兩者矛盾。

  11C++語(yǔ)言中關(guān)于構造函數的說(shuō)法正確的是(  )。

  A.構造函數的函數名不必和類(lèi)名相同

  B.構造函數只能有一個(gè)

  C.每個(gè)類(lèi)必定有構造函數

  D.構造函數必有返回值

  參考答案:C

  參考解析:本題考查構造函數的概念。構造函數可以被重載,函數名必須和類(lèi)名相同;構造函數可以有一個(gè),也可以有多個(gè);構造函數沒(méi)有返回值。

  12下列描述中,錯誤的是(  )。

  A.公有繼承時(shí)基類(lèi)中的公有成員在派生類(lèi)中仍是公有成員

  B.公有繼承時(shí)基類(lèi)中的保護成員在派生類(lèi)中仍是保護成員

  C.保護繼承時(shí)基類(lèi)中的公有成員在派生類(lèi)中仍是公有成員

  D.保護繼承時(shí)基類(lèi)中的保護成員在派生類(lèi)中仍是保護成員

  參考答案:C

  參考解析:保護繼承時(shí),類(lèi)成員的訪(fǎng)問(wèn)級別只能降低為保護模式,因此即使是基類(lèi)的公有成員也被縮小為保護模式。

  13結構化程序所要求的基本結構不包括(  )。

  A.順序結構B.GOTO跳轉C.選擇(分支)結構D.重復(循環(huán))結構

  參考答案:B

  參考解析:結構化程序設計的三種結構是順序、分支和循環(huán),不包括goto跳轉,它只是分支結構的一種,也是一個(gè)關(guān)鍵字。

  14在E—R圖中,用來(lái)表示實(shí)體聯(lián)系的圖形是(  )。

  A.橢圓圖B.矩形C.菱形D.三角形

  參考答案:C

  參考解析:E—R圖中用矩形表示實(shí)體(等同于表),用橢圓形表示實(shí)體的屬性(等同于表中字段),用菱形表示實(shí)體關(guān)系(等同于外鍵)。

  15下列數據結構中,屬于非線(xiàn)性結構的是(  )。

  A.循環(huán)隊列B.帶鏈隊列C.二叉樹(shù)D.帶鏈棧

  參考答案:C

  參考解析:隊列是一種允許在一端進(jìn)行插入,而在另一端進(jìn)行刪除的線(xiàn)性表。棧也是一種特殊的線(xiàn)性表,其插入與刪除只能在線(xiàn)性表的一端進(jìn)行。

  16對長(cháng)度為n的線(xiàn)性表進(jìn)行順序查找,在最壞情況下所需要的比較次數為(  )。

  A.log2nB.n/2C.nD.n+1

  參考答案:C

  參考解析:對線(xiàn)性表進(jìn)行順序查找,最壞情況下,如果從表頭進(jìn)行查找,要查找到表尾才能得出結果,因此需要比較n次。

  17下面程序的運行結果為(  )。#include

  voidswap(int&a,intb)

  {

  inttemp;

  temp=a++;

  a=b:

  b=temp:

  }

  voidmain()

  {

  inta=2,b=3;

  swap(a,b);

  cout<

  }

  A.2,3B.3,2C.2,2D.3,3

  參考答案:D

  參考解析:本題考查引用調用,因為函數swap引用調用參數a,所以在swap函數中a的變化會(huì )改變主函數中a的值,即a自加1。但b的值并未改變。

  18若有以下程序:

  #include

  usingnamespacestd;

  classBase

  {public:

  Base()

  {x=0;}

  intx;};

  classDerivedl:virtualpublicBase

  {public:

  Derivedl()

  {x=10;}};

  classDerived2:virtua11publicBase

  {public:

  Derived2()

  {x=20;}};

  classDerived:publicDerivedl,protectedDerived2{};intmain()

  {Derivedobj;

  cout<

  return0;}

  該程序運行后的輸出結果是(  )。

  A.20B.30C.10D.0

  參考答案:A

  參考解析:本題考查虛基類(lèi)的應用。雖然Derivedl和Derived2都是由共同的基類(lèi)x派生而來(lái)的,但由于引入了虛基類(lèi),使得它們分別對應基類(lèi)的不同副本。這時(shí)數據成員x只存在一份副本,不論在類(lèi)Derivedl中修改,還是在Derived2中修改,都是直接對這唯一副本進(jìn)行操作。本題程序執行語(yǔ)句“Derivedobj;”時(shí).就會(huì )先調虛基類(lèi)Base的構造函數,使得X=0,然后執行類(lèi)Derivedl的構造函數使得x=10,再執行類(lèi)Derived2的構造函數,使得x=20。最后輸出x的值為20。

  19下列選項中不合法的標識符是(  )。

  A.printB.FORC.&aD.-00

  參考答案:C

  參考解析:標識符的概念只能由數字、字母和下畫(huà)線(xiàn)組成,并且只能以字母和下畫(huà)線(xiàn)開(kāi)頭,所以選項C不正確。

  20考慮函數原型voidtest(inta,intb=7,charz='*'),下面的函數調用中,屬于不合法調用的是(  )。

  A.test(5);B.test(5,8);C.test(6,'#');D.test(0,0,'*');

  參考答案:C

  參考解析:題中函數聲明帶有默認參數,那么在C選項的調用中,將會(huì )把字符型實(shí)參#賦值給整型形參b,這不符合參數傳遞規則。

  21當需要將一個(gè)函數boolisnunlber(charc)聲明為內聯(lián)函數時(shí),此內聯(lián)函數的函數原型為(  )。

  A.enumboolisnumber(charc);

  B.defineboolisnumber(charc);

  C.inlineboolisnumber(charc);

  D.extemboolisnumber(charc);

  參考答案:C

  參考解析:本題考查內聯(lián)函數的相關(guān)知識點(diǎn)。函數原型應指出函數名、返回值類(lèi)型以及在調用函數時(shí)提供的參數的個(gè)數和類(lèi)型,因為要聲明為內聯(lián)函數,故應加inline關(guān)鍵字。

  22有如下程序:

  #include

  usingnamespacestd;

  intmain(  ){

  inta[6]={23,l5,64,33,40,58};

  ints1,s2;

  s1=s2=a[0];

  for(int*p=a+1;p

  if(sl>*p)s1=*P;

  if(s2<*p)s2=*p;

  }

  cout<

  return0;

  }

  運行時(shí)的輸出結果是(  )。

  A.23B.58C.64D.79

  參考答案:D

  參考解析:根據題意,找出數組a中最大值sl和最小值s2并計算二者的和。

  23以下程序中調用cin函數給變量a輸入數值的方法是錯誤的,其錯誤的原因是(  )。

  #include(iostream.h)

  voidmain(  )

  {int*P,*q,a,b;

  p=&a;

  cout<<"inputa:";

  cin>>P;

  }

  A.*P表示的是指針變量P的地址

  B.P表示的是變量a的地址,而不是變量a的值

  C.*P表示的是指針變量p的值

  D.*P只能用來(lái)說(shuō)明P是一個(gè)指針變量

  參考答案:B

  參考解析:p表示的是變量a的地址,定義后*P表示的是變量a的值。

  24有以下程序:

  classDate

  {

  public:

  Date(inty,intm,intd);

  {

  year=Y:

  month=m;

  day=d;

  }

  Date(inty=2000)

  {

  year=y;

  month=10;

  day=1;

  }

  Date(Date&d)

  {

  year=d.year;

  month=d.month;

  day=d.day;

  }

  voidprint(  )

  {

  cout<

  }

  private:

  intyear,month,day;

  };

  Datefun(Dated)

  {

  Datetemp;

  temp=d;

  returntemp;

  }

  intmain(  )

  {

  Datedatel(2000,1,1),date2(0,0,0);

  Datedate3(datel);

  date2=fun(date3);

  return0;

  }

  程序執行時(shí),Date類(lèi)的拷貝構造函數被調用的次數是(  )。

  A.2B.3C.4D.5

  參考答案:B

  參考解析:本題考核拷貝構造函數。上述程序中,拷貝構造函數一共被調用了3次:第1次是在執行語(yǔ)句Datedate3(date1)時(shí),用已經(jīng)建立的對象date1對正在建立的對象date3進(jìn)行初始化;第2次是在調用fun函數時(shí),由于是傳值調用,因此實(shí)參對象date3要對形參對象d進(jìn)行初始化;第3次是在執行fun函數中的返回語(yǔ)句returntemp;時(shí),系統初始化一個(gè)匿名對象時(shí)使用了拷貝構造函數。

  25下面程序的輸出結果是(  )。

  #include

  Usingnamespacestd;

  ClassBase{

  public:

  Base(intx=O){count<

  }

  };

  ClassDerived:publicBase{

  public:Derved(intx=0{count<

  }

  private;

  Baseval;

  };

  intmina(){

  Derivedd(1);

  retrun0;

  }

  A.0B.1C.01D.001

  參考答案:D

  26軟件設計中劃分模塊的一個(gè)準則是(  )。

  A.低內聚低耦合B.高內聚低耦合C.低內聚高耦合D.高內聚高耦合

  參考答案:B

  參考解析:耦合性與內聚性是模塊獨立性的兩個(gè)定性標準,耦合與內聚是相互關(guān)聯(lián)的。在程序結構中,各個(gè)模塊的內聚性越強,則耦合性越弱。一般較優(yōu)秀的軟件設計,應盡量做到高內聚、低耦合,即減弱模塊之間的耦合性和提高模塊內的內聚性,有利于提高模塊的獨立性。

  27下列程序的運行結果是(  )。

  #include

  intx=5;

  intfun(inta)

  {

  intc:

  c=X*a:

  returnC;

  }

  voidmain()

  {

  intx=3,a=4;

  x=x+fun(a);

  cout<<"x="<

  }

  A.x=15B.x=17C.x=23D.x=25

  參考答案:C

  參考解析:由主函數main入手,首先x被賦值為3,a被賦值為4,然后調用fun函數,參數為4,所以在fun函數中的a=4。而主程序中的x作用域是由它定義開(kāi)始到cout輸出,在fun函數中無(wú)效。而在fun函數定義前的變量X作用域是整個(gè)程序,所以fun函數中的x值為5,這樣C的值就為20。在主函數中的x+fun(a)中的x為靠近這條語(yǔ)句的x定義,即3,所以最后x的值為20+3=23。第27題 筆記記錄我的筆記(0) | 精選筆記(0)選擇筆記標簽:試題內容(0)答案解析(0)

  28數據庫DB、數據庫系統DBS、數據庫管理系統DBMS之間的關(guān)系是(  )。

  A.DB包含DBS和DBMSB.DBMS包含DB和DBSC.DBS包含DB和DBMSD.沒(méi)有任何關(guān)系

  參考答案:C

  參考解析:數據庫系統(DBS)是指在計算機系統中引入數據庫后的系統,一般有數據庫(DB)、數據庫管理系統(DBMS)、應用系統、數據庫管理員和用戶(hù)構成。

  29在軟件開(kāi)發(fā)中,需求分析階段產(chǎn)生的主要文檔是(  )。

  A.軟件集成測試計劃B.軟件詳細設計說(shuō)明書(shū)C.用戶(hù)手冊D.軟件需求規格說(shuō)明書(shū)

  參考答案:D

  參考解析:需求分析階段只能產(chǎn)生需求分析規格說(shuō)明書(shū),A測試說(shuō)明書(shū)是軟件測試階段生成的,B軟件詳細設計說(shuō)明數是設計階段生產(chǎn),C用戶(hù)手冊是軟件發(fā)布時(shí)隨軟件一同交付給用戶(hù)的。

  30有如下程序:

  #include

  usingnamespacestd;

  classXA{

  inta;

  public:

  staticintb;

  XA(intaa):a(aa){b++;}

  ~XA(  ){}

  intget(  ){returna;}

  };

  intXA::b=0

  intmain(  ){

  XAd1(1),d2(3);

  cout<

  return0;

  }

  運行時(shí)的輸出結果是(  )。

  A.5B.6C.7D.8

  參考答案:C

  參考解析:每調用一次get函數時(shí),對新的類(lèi)A對象進(jìn)行一次實(shí)例化,調用一次構造函數,類(lèi)A的靜態(tài)成員變量b便加1。

  二、程序改錯題

  41使用VC++6.0打開(kāi)考生文件夾下的源程序文件1.cpp,該程序運行時(shí)有錯。請改正程序中的錯誤,使程序輸出的結果為

  100

  37

  32

  注意:錯誤的語(yǔ)句在//******error******的下面,修改該語(yǔ)句即可。

  試題程序:

  #include

  //******error******

  voidmain

  {

  //******error******

  intm=0142:

  //******error******

  intn=0X27:

  intq=32;

  cout<

  cout<

  cout<

  return;

  }

  參考解析:

  (1)“voidmain()”。

  (2)“intm=0144;”。

  (3)“intn=OX25;”或“intn===0x25;”。

  【解析】本題主要考查了主函數定義及冪同進(jìn)制之間的轉換,包括十進(jìn)制到八進(jìn)制,十進(jìn)制到十六進(jìn)制。主函數定義的定義形式為“main()”,函數名之后必須是一對括號,因此第1處應改為“voidmain()”。cout輸出默認是以十進(jìn)制方式輸出的,根據題目要求輸出的結果可發(fā)現變量的初值不正確,十進(jìn)制的100對應八進(jìn)制的144,卡進(jìn)制的37對應十六進(jìn)制的25,因此2和3應分別改成“intm=0144;”,“intn=0×25;”或“intn=0×25;”。

  三、簡(jiǎn)單應用題

  42使用VC++6.0打開(kāi)考生文件夾下的源程序文件2.cpp。請完成函數fun(intn),使其實(shí)現以下功能:當i等于3時(shí),則打印如下內容。

  A

  AA

  AAA

  注意:不能修改程序的其他部分,只能修改fun函數。

  試題程序:

  #include

  voidfun(intn)

  {

  }

  voidmain()

  {

  intn;

  cout<<"請輸入打印的行數:"<

  cin>>n;

  if(n<1)

  {

  cout<<"輸入的行數必須大于0"<

  return;

  }

  fun(n);

  return;

  }

  參考解析:

  inti;

  for(i=0;i

  {

  intj;

  for(j=0;j(n-i-1;j++)//循環(huán)打印空格

  {

  cout<<'';

  }

  for(;j

  {

  cout<<"A":

  }

  cout<

  }

  【解析】本題利用外層循環(huán)打印每一行。內層循環(huán)分為

  打印空格和打印A。打印空格由第一個(gè)位置到第n-i-1。打印A,是由打印完空格開(kāi)始一直到行結束。在外循環(huán)中打印每一行的結束符。

  四、綜合應用題

  43使用VC++6.0打開(kāi)考生文件夾下的源程序文件3.cpp。請完成以下部分,實(shí)現在屏幕上輸出為

  C3

  C2

  這個(gè)程序需要修改的部分,請按照以下部分實(shí)現。

  (1)類(lèi)C0不能被實(shí)例化,請定義一個(gè)純虛函數print,在注釋1后添加適當的語(yǔ)句。

  (2)類(lèi)C1私有虛繼承類(lèi)C0,請在注釋2后添加適當的語(yǔ)句。

  (3)類(lèi)C2公有繼承于C0,請在注釋3后添加適當的語(yǔ)句。

  (4)類(lèi)c3公有繼承于C2與C1,請在注釋4后添加適當的語(yǔ)句。

  注意:增加代碼或者修改代碼的位置已經(jīng)用符號表示出來(lái)。請不要修改其他的程序代碼。

  試題程序:

  #include(iostream.h)

  classCO

  {

  //********1********

  };

  //********2********

  classC1:

  {

  public:

  voidprint()

  {

  cout<"”C1"<

  }

  };

  //********3********

  classC2:

  {

  public:

  voidprint()

  {

  cout<<"C2"<

  }

  };

  //********4***x****

  classC3:

  {

  public:

  voidprint()

  {

  cout<<"C3"<

  }

  };

  voidmain()

  {

  C30bj3;

  C20bj2;

  obj3.print();

  obj2.print();

  return;

  }

  參考解析:

  (1)應添加“virtualvoidprint()=0,”。

  (2)“classC1:”應改為“classC1:virtualprivateC0”。

  (3)“classC2:”應改為“classC2:publicC0”。

  (4)“classC3:”應改為“classC3:publicC2,publicC1”。

  【解析】本題考查了類(lèi)的繼承。根據題意,第1處應該添加“virtualvoidprint()=0;”。第2處根據題意,在冒號后面應添加“virtualprivateCO”。第3處根據題意,冒號后應添加“publicCO”。第4處根據題意,冒號后應添加“publicC2,publicC1”。

【計算機二級模擬試題及答案】相關(guān)文章:

計算機二級考試模擬試題及答案03-13

計算機二級Access模擬試題及答案06-11

計算機二級考試word模擬試題及答案03-08

計算機二級《C語(yǔ)言》模擬試題及答案03-29

計算機二級《MS Office》高級模擬試題及答案03-10

計算機二級《公共基礎》模擬試題及答案201703-10

2017計算機二級題庫office模擬試題及答案03-10

計算機二級基礎知識模擬試題及答案201602-27

2024年計算機二級office模擬試題及答案10-25

激情欧美日韩一区二区,浪货撅高贱屁股求主人调教视频,精品无码成人片一区二区98,国产高清av在线播放,色翁荡息又大又硬又粗视频