亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

計(jì)算機(jī)等級(jí)

計(jì)算機(jī)二級(jí)c語言真題及答案

時(shí)間:2024-09-19 03:07:12 計(jì)算機(jī)等級(jí) 我要投稿
  • 相關(guān)推薦

2016年計(jì)算機(jī)二級(jí)c語言真題及答案

  2016下半年計(jì)算機(jī)考試時(shí)間暫未公布,以下yjbys小編先為大家提供計(jì)算機(jī)C語言考試真題及答案,希望對(duì)大家復(fù)習(xí)有所幫助!

  一、單選題

  (1)下列敘述中正確的是

  A)棧是“先進(jìn)先出”的線性表 B)隊(duì)列是“先進(jìn)先出”的線性表

  C)循環(huán)隊(duì)列是非線性結(jié)構(gòu) D)有序性表既可以采用順序存儲(chǔ)結(jié)構(gòu),也可以采用鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)

  (2)支持子程序調(diào)用的數(shù)據(jù)結(jié)構(gòu)是 A)棧 B)樹 C)隊(duì)列 D)二叉樹

  (3)某二叉樹有5個(gè)度為2的結(jié)點(diǎn),則該二叉樹中的葉子結(jié)點(diǎn)數(shù)是 A)10 B)8 C)6 D)4

  (4)下列排序方法中,最壞情況下比較次數(shù)最少的是

  A)冒泡排序 B)簡單選擇排序 C)直接插排序 D)堆排序

  (5)軟件按功能可以分為:應(yīng)用軟件、系統(tǒng)軟件和支撐軟件(或工具軟件)。下面屬于應(yīng)用軟件的是

  A)編譯軟件 B)操作系統(tǒng) C)教務(wù)管理系統(tǒng) D)匯編程序

  (6)下面敘述中錯(cuò)誤的是

  A)軟件測(cè)試的目的是發(fā)現(xiàn)錯(cuò)誤并改正錯(cuò)誤 B)對(duì)被調(diào)試的程序進(jìn)行“錯(cuò)誤定位”是程序調(diào)試的必要步驟

  C)程序調(diào)試通常也稱為Debug D)軟件測(cè)試應(yīng)嚴(yán)格執(zhí)行測(cè)試計(jì)劃,排除測(cè)試的隨意性

  (7)耦合性和內(nèi)聚性是對(duì)模塊獨(dú)立性度量的兩個(gè)標(biāo)準(zhǔn)。下列敘述中正確的是

  A)提高耦合性降低內(nèi)聚性有利于提高模塊的獨(dú)立性 B)降低耦合性提高內(nèi)聚性有利于提高模塊的獨(dú)立性

  C)耦合性是指一個(gè)模塊內(nèi)部各個(gè)元素間彼此結(jié)合的緊密程度 D)內(nèi)聚性是指模塊間互相連接的緊密程度

  (8)數(shù)據(jù)庫應(yīng)用系統(tǒng)中的核心問題是

  A)數(shù)據(jù)庫設(shè)計(jì) B)數(shù)據(jù)庫系統(tǒng)設(shè)計(jì) C)數(shù)據(jù)庫維護(hù) D)數(shù)據(jù)庫管理員培訓(xùn)

  (9)有兩個(gè)關(guān)系R,S如下:

  R

  A

  B

  C

  a

  3

  2

  b

  0

  1

  c

  2

  1

  S

  A

  B

  a

  3

  b

  0

  c

  2

  由關(guān)系R通過運(yùn)算得到關(guān)系S,則所使用的運(yùn)算為A)選擇 B)投影 C)插入 D)連接

  (10)將E-R圖轉(zhuǎn)換為關(guān)系模式時(shí),實(shí)體和聯(lián)系都可以表示為A)屬性 B)鍵 C)關(guān)系 D)域

  (11)以下選項(xiàng)中合法的標(biāo)識(shí)符是A) 1-1 B)1—1 C)-11 D)1--

  (12)若函數(shù)中有定義語句:int k;,則

  A)系統(tǒng)將自動(dòng)給k賦初值0B)這時(shí)k中值無定義C)系統(tǒng)將自動(dòng)給k賦初值-1D)這時(shí)k中無任何值

  (13)以下選項(xiàng)中,能用作數(shù)據(jù)常量的是 A)o115 B) 0118 C)1.5e1.5 D) 115L

  (14)設(shè)有定義:int x=2;,以下表達(dá)式中,值不為6的是 A) x*=x+1 B) x++,2*x C)x*=(1+x) D)2*x,x+=2

  (15)程序段:int x=12;

  double y=3.141593; printf(“%d%8.6f”,x,y);的輸出結(jié)果是

  A)123.141593 B)123.141593 C)12,3.141593 D)123.141593

  (16)若有定義語句:double x,y,*px,*py,執(zhí)行了px=&x, py=&y;之后,正確的輸入語句是

  A)scanf(“%f%f”,x,y);B) scanf(“%f%f”,&x,&y);C) scanf(“%lf%le”,px,py);D) scanf(“%lf%lf”,x,y);

  (17)以下是if語句的基本形式:

  if(表達(dá)式)

  語句

  其中“表達(dá)式”

  A)必須是邏輯表達(dá)式B)必須是關(guān)系表達(dá)式C)必須是邏輯表達(dá)式或關(guān)系表達(dá)式D)可以是任意合法的表達(dá)式

  (18)有以下程序

  #include

  main()

  {int x;

  scanf(“%d”,&x);

  if(x<=3); else

  if(x!=10)

  printf(“%d\n”,x);} 程序運(yùn)行時(shí),輸入的值在哪個(gè)范圍才會(huì)有輸出結(jié)果

  A)不等于10的整數(shù)B)大于3且不等于10的整數(shù)C)大于3或等于10的整數(shù)D)小于3的整數(shù)

  (19)有以下程序

  #include

  Main()

  { int a=1,b=2,c=3,d=0;

  if(a= =1 &&b++= =2)

  if(b!=2 || c--!=3)

  printf(“%d,%d,%d\n”,a,b,c);

  else printf(“%d,%d,%d\n”,a,b,c);

  else printf(“%d,%d,%d\n”,a,b,c);} 程序運(yùn)行后的輸出結(jié)果是

  A)1,2,3 B)1,3,2 C)1,3,3 D)3,2,1

  (20)以下程序中的變量已正確定義

  for(i=0;i<4;i++,i++

  for(k=1;k<3;k++);printf(*”); 程序段的輸出結(jié)果是

  A)******** B)**** C)** D)*

  (21)有以下程序

  #include

  main()

  {char

  *s=(“ABC);

  do

  {printf(“%d”,*s);s++;

  }while(*s);} 注意,字母A的ASCII碼值為65。程序運(yùn)行后的輸出結(jié)果是

  A)5670 B)656667 C)567 D)ABC

  (22)設(shè)變量已正確定義,以下不能統(tǒng)計(jì)出一行中輸入字符個(gè)數(shù)(不包含回車符)的程序段是

  A)n=0;while((ch=getchar())!=’\n’)n++; B) n=0;while(getchar()!=’\n’)n++;

  C)for(n=0; getchar()!=’\n’;n++); D)n=0;for(ch=getchar();ch!=’\n’;n++);

  (23)有以下程序

  #include

  main()

  { int a1,a2;char c1,c2;

  scanf(“%d%c%d%c”,&a1,&c1,&a2,&c2);

  printf(“%d,%c,%d,%c”,&1,c1,a2,c2);}

  若想通過鍵盤輸入,使得a1的值為12,a2的是為34,c1的值為字符a,c2的值為字符b,程序輸出結(jié)果是:12,a,34,b,則正確的輸入格式是(以下代表空格,代表回車)

  A)12a34b C)12,a,34,b

  B)12 D)12

  a a34

  34 b

  b

  24)有以下程序

  #include

  int f(int x,int y)

  {return()y-x)*x);}

  main()

  {int a=3,b=4,c=5,d;

  d=f(f(a,b),f(a,c));

  printf(“%d\n”,d);} 程序運(yùn)行后的輸出結(jié)果是

  A)10 B)9 C)8 D)7

  (25)有以下程序

  #include

  void fun(char

  *s)

  {while(*s)

  { if(*s%2==0)

  printf(“%c”,*s);

  s++;}}

  main()

  { char

  a[]={“good”};

  fun(a);printf(“\n”);}注意:字母a的ASCⅡ碼值為97,程序運(yùn)行后的輸出結(jié)果是

  A)d B)go C)god D)good

  (26)有以下程序

  #include

  void fun( int *a,int *b)

  {int *c;

  c=a;a=b;b=c;}

  main()

  {int x=3,y-5,*P=&x,*q=&y;

  fun(p,q);printf(“%d,%d,”,*p,*q);

  fun(&x,&y);printf(“%d,%d\n”,*p,*q);} 程序運(yùn)行后的輸出結(jié)果是

  A)3,5,5,3 B)3,5,3,5 C)5,3,3,5 D)5,3,5,3

  (27)有以下程序

  #include

  viod f(int *p,int *q);

  main()

  { int m=1,n=2,*r=&m;

  f(r,&n);printf(“%d,%d”,m,n);}

  void f(int *p,int *q)

  {p=p+1;*q=*q+1;}程序運(yùn)行后輸出的結(jié)果是

  A)1,3 B)2,3 C)1,4 D)1,2

  (28)以下函數(shù)按每行8個(gè)輸出數(shù)組中的數(shù)據(jù)

  void fun( int *w,int n)

  { int i;

  for(i=0;i

  {_________________

  printf(“%d”,w);}

  printf(“\n”);} 下劃線處應(yīng)填入的語句是

  A)if(i/8==0)print(“\n”); B) if(i/8==0)continue;

  C) if(i%8==0)print(“\n”); D) if(i%8==0)continue;

  (29)若有以下定義 int x[10],*pt=x; 則對(duì)x數(shù)組元素的正確應(yīng)用是

  A)*&x[10] B)*(x+3) C)*(pt+10) D)pt+3

  30)設(shè)有定義:char s[81];int i=10;,以下不能將一行(不超過80個(gè)字符)帶有空格的字符串真確讀入的語句或語句組是

  A) gets(s) B)while((s[i++]=getchar())!=”\n”;s=”\0”;

  C)scanf(“%s”,s); D)do{scanf(“%c”,&s);}while(s[i++]!=”\n”);s=”\0”;

  (31)有以下程序

  #include

  main()

  { char *a[ ]={“abcd”,”ef”,”gh”,”ijk”};int I;

  for(i=0;i<4;i++)

  printf(“%c”,*a);} 程序運(yùn)行后輸出的結(jié)果是

  A)aegi B)dfhk C)abcd D)abcdefghijk

  32)以下選項(xiàng)中正確的語句組是

  A)char s[];s=”BOOK!”; B) char *s;s={”BOOK!”}; C)char s[10];s=”BOOK!”; D) char *s;s=”BOOK!”;

  (33)有以下程序

  #include

  int fun{int x,int y}

  { if(x==y) return(x);

  else returen((x+y)/2)}

  main()

  { int a=4,b=5,c=6;

  printf(“%d\n”,fun(2*a,fun(b,c)))} 程序運(yùn)行后的輸出結(jié)果是

  A)3 B)6 C)8 D)12

  (34)設(shè)函數(shù)中有整型變量n,為保證其在未賦值的情況下初值為0,應(yīng)選擇的存儲(chǔ)類別是

  A)auto B) register C)static D)auto或register

  (35)有以下程序

  #include

  int b=2;

  int fun(int *k)

  { b=*k+b;return(b);}

  main()

  { int a[10]={1,2,3,4,5,6,7,8},I;

  for(i=2;i<4;i++) {b=fun(&a)+b;printf(“%d”,b);}

  printf(“\n”);}程序運(yùn)行后輸出的結(jié)果是

  A)10 B)8 C)10 D)10

  12 10 28 16

  36)有以下程序

  #include

  #define PT 3.5;

  #define S(x) PT*x*x;

  mian()

  { int a=1, b=2; printf(“%4.1f\n”,S(a+b));}程序運(yùn)行后輸出的結(jié)果是

  A)14.0 B)31.5 C)7.5 D)程序有錯(cuò)無輸出結(jié)果

  37)有以下程序

  #include

  struct ord

  { int x,y;} dt[2]={1,2,3,4};

  main()

  { struct ord *p=dt;

  printf(“%d,”,++p->x); printf(“%d\n”,++p->y);}程序的運(yùn)行結(jié)果是

  A)1,2 B)2,3 C)3,4 D)4,1

  38)設(shè)有宏定義:#include

  IsDIV(k,n) ((k%n==1)?1:0且變量m已正確定義并賦值,則宏調(diào)用:IsDIV(m,5)&& IsDIV(m,7)為真時(shí)所要表達(dá)的是 A)判斷m是否能被5或者7整除 B)判斷m是否能被5和7整除

  C)判斷m被5或者7整除是否余1 D)判斷m被5和7整除是否余1

  (39)有以下程序

  #include

  main()

  { int a=5,b=1,t;

  t=(a<<2|b); printf(“%d\n”,t)}程序運(yùn)行后的輸出結(jié)果是 A)21 B)11 C)6 D)1

  (40)有以下程序

  #include

  main()

  { EILE *f;

  f=fopen(“filea.txt”,”w”);

  fprintf(f,”abc”);

  fclose(f);} 若文本文件filea.txt中原有內(nèi)容為:hello,則運(yùn)行以上程序后,文件filea.txt中的內(nèi)容為

  A) helloabc B)abclo C)abc D)abchello

  二、填空題(每空2分,共30分)

  (1)假設(shè)一個(gè)長度為50的數(shù)組(數(shù)組元素的下標(biāo)從0到49)作為棧的存儲(chǔ)空間,棧底指針bottom指向棧底元素,棧頂指針top指向棧頂元素,如果bottom=49,top=30(數(shù)組下標(biāo)),則棧中具有【1】個(gè)元素。

  (2)軟件測(cè)試可分為白盒測(cè)試和黑盒測(cè)試;韭窂綔y(cè)試屬于 【2】測(cè)試。

  (3)符合結(jié)構(gòu)化原則的三種基本控制結(jié)構(gòu)是:選擇結(jié)構(gòu)、循環(huán)結(jié)構(gòu)和【3】。

  (4)數(shù)據(jù)庫系統(tǒng)的核心是 【4】

  (5)在E-R圖中,圖形包括矩形框、菱形框、橢圓框。其中表示實(shí)體聯(lián)系的是【5】框。

  (6)表達(dá)式(int)((double)(5/2)+2.5)的值是【6】

  (7)若變量x、y已定義為int類型且x的值為99,y的值為9,請(qǐng)將輸出語句printf(【7】,x/y);補(bǔ)充完整,使其輸出的計(jì)算結(jié)果形式為:x/y=11

  (8)有以下程序

  #include

  main( )

  {char c1,c2;scanf(“&c”,&c1);

  while(c1<65||c1>90)

  scanf(“&c”,&c1);

  c2=c1+32;

  printf(“&c, &c\n”,c1,c2);} 程序運(yùn)行輸入65回車后,能否輸出結(jié)果、結(jié)束運(yùn)行(請(qǐng)回答能或不能)【8】。

  (9)以下程序運(yùn)行后的輸出結(jié)果是【9】

  #include

  main( )

  {int k=1,s=0;

  do{

  if{((k&2)!=0)continue;

  s+=k;k++;

  }while(k)10);

  printf(“s=&d/n”,s);}

  (10)下列程序運(yùn)行時(shí),若輸入labced12df<回車>輸出結(jié)果為【10】

  #include

  main( )

  {char

  a =0,ch;

  while((ch=getchar())!=’\n’)

  {if(a&2!=0&&(ch>’a’&&ch<=’z’)) ch=ch-‘a’+’A’;

  a++;putchar(ch);}

  printf(“\n”);}

  (11)有以下程序,程序執(zhí)行后,輸出結(jié)果是【11】

  #include

  void fun (int *a)

  {a[0=a[1];]}

  main()

  {int a[10]={10,9,8,7,6,5,4,3,2,1},i;

  for(i=2;i>=0;i--) fun{&a};

  for(i=0;i<10;i++) printf(“&d”,a);

  printf(“\n”);

  }

  (12)請(qǐng)將以下程序中的函數(shù)聲明語句補(bǔ)充完整

  #include

  int【12】;

  main( )

  {int x,y,(*p)();

  p=max;

  printf(“&d\n”,&x,&y);}

  Int max(int a,int b)

  {return (a>b/a:b);}

  (13)以下程序用來判斷指定文件是否能正常打開,請(qǐng)?zhí)羁?/p>

  #include

  main( )

  {FILE *fp;

  if (((fp=fopen(“test.txt”,”r”))==【13】))

  printf(“未能打開文件!\n”);

  else

  printf(“文件打開成功!\n”);

  (14)下列程序的運(yùn)行結(jié)果為【14】

  #include

  #include

  struct A

  {int a;char b[10];doublec;};

  void

  f (struct

  A

  *t);

  main()

  {struct A a=(1001,”ZhangDa”,1098,0);

  f(&a);printf(“&d,&s,&6,if\n”,a.a,a.b,a.c);}

  void f(struct

  A

  *t)

  {strcpy(t->b,”ChangRong”);}

  (15)以下程序把三個(gè)NODETYPE型的變量鏈接成一個(gè)簡單的鏈表,并在while循環(huán)中輸出鏈表結(jié)點(diǎn)數(shù)據(jù)域中的數(shù)據(jù),請(qǐng)?zhí)羁?/p>

  #include

  struct node

  {int data; struct node *next;};

  typedef struct node NODETYPE;

  main()

  {NODETYPE a,b,c,*h,*p;

  a.

  data=10;b.data=20;c.data=30;h=&a;

  b.

  next=&b;b.next=&c;c.next=’\0’;

  p=h;

  while(p){printf(“&d”,p->data);【15】;}

  }

  【參考答案】

  選擇題:

  1~10: DACDCABABC 11~20:CBDDACDBCB 21~30:CDABABACBC 31~4ADBCCCBDAC

  填空題:(1)19(2)白盒(3)順序結(jié)構(gòu)(4)數(shù)據(jù)庫管理系統(tǒng)(DBMS)(5)菱形(6)4(7)"x/y=%d"(8)能(9)s=0(10)1AbCeDf2dF(11)7777654321(12)max(int a,int b)(13)NULL

  (14)1001,ChangRong,1098.0(15)p=p—>next