• <sub id="h4knl"><ol id="h4knl"></ol></sub>
    <sup id="h4knl"></sup>
      <sub id="h4knl"></sub>

      <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
      1. <strong id="h4knl"></strong>

      2. 計(jì)算機(jī)二級(jí)C語(yǔ)言筆試歷年真題及答案

        時(shí)間:2024-09-30 11:25:30 海潔 計(jì)算機(jī)等級(jí) 我要投稿
        • 相關(guān)推薦

        計(jì)算機(jī)二級(jí)C語(yǔ)言筆試歷年真題及答案

          在現(xiàn)實(shí)的學(xué)習(xí)、工作中,我們最熟悉的就是試題了,借助試題可以更好地檢查參考者的學(xué)習(xí)能力和其它能力。你知道什么樣的試題才是好試題嗎?下面是小編收集整理的計(jì)算機(jī)二級(jí)C語(yǔ)言筆試歷年真題及答案,希望對(duì)大家有所幫助。

        計(jì)算機(jī)二級(jí)C語(yǔ)言筆試歷年真題及答案

          計(jì)算機(jī)二級(jí)C語(yǔ)言筆試歷年真題及答案 1

          一、選擇題(每小題2分,共70分)

          下列各題A)、B)、C)、D)四個(gè)選項(xiàng)中,只有一個(gè)選項(xiàng)是正確的。請(qǐng)將正確選項(xiàng)填涂在答題卡相應(yīng)位置上,答在試卷上不得分。

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

          A)線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)與順序存儲(chǔ)結(jié)構(gòu)所需要的存儲(chǔ)空間是相同的

          B)線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)所需要的存儲(chǔ)空間一般要多于順序存儲(chǔ)結(jié)構(gòu)

          C)線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)所需要的存儲(chǔ)空間一般要少于順序存儲(chǔ)結(jié)構(gòu)

          D)上述三種說(shuō)法都不對(duì)

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

          A)在棧中,棧中元素隨棧底指針與棧頂指針的變化而動(dòng)態(tài)變化

          B)在棧中,棧頂指針不變,棧中元素隨棧底指針的變化而動(dòng)態(tài)變化

          C)在棧中,棧底指針不變,棧中元素隨棧頂指針的變化而動(dòng)態(tài)變化

          D)上述三種說(shuō)法都不對(duì)

          (3)軟件測(cè)試的目的是

          A)評(píng)估軟件可靠性

          B)發(fā)現(xiàn)并改正程序中的錯(cuò)誤

          C)改正程序中的錯(cuò)誤

          D)發(fā)現(xiàn)程序中的錯(cuò)誤

          (4)下面描述中,不屬于軟件危機(jī)表現(xiàn)的是

          A)軟件過(guò)程不規(guī)范

          B)軟件開(kāi)發(fā)生產(chǎn)率低

          C)軟件質(zhì)量難以控制

          D)軟件成本不斷提高

          (5)軟件生命周期是指

          A)軟件產(chǎn)品從提出、實(shí)現(xiàn)、使用維護(hù)到停止使用退役的過(guò)程

          B)軟件從需求分析、設(shè)計(jì)、實(shí)現(xiàn)到測(cè)試完成的過(guò)程

          C)軟件的開(kāi)發(fā)過(guò)程

          D)軟件的運(yùn)行維護(hù)過(guò)程

          (6)面向?qū)ο蠓椒ㄖ校^承是指

          A)一組對(duì)象所具有的相似性質(zhì)

          B)一個(gè)對(duì)象具有另一個(gè)對(duì)象的性質(zhì)

          C)各對(duì)象之間的共同性質(zhì)

          D)類之間共享屬性和操作的機(jī)制

          (7)層次型、網(wǎng)狀型和關(guān)系型數(shù)據(jù)庫(kù)劃分原則是

          A)記錄長(zhǎng)度

          B)文件的大小

          C)聯(lián)系的復(fù)雜程度

          D)數(shù)據(jù)之間的聯(lián)系方式

          (8)一個(gè)工作人員可以使用多臺(tái)計(jì)算機(jī),而一臺(tái)計(jì)算機(jī)可被多個(gè)人使用,則實(shí)體工作人員、與實(shí)體計(jì)算機(jī)之間的聯(lián)系是

          A)一對(duì)一

          B)一對(duì)多

          C)多對(duì)多

          D)多對(duì)一

          (9)數(shù)據(jù)庫(kù)設(shè)計(jì)中反映用戶對(duì)數(shù)據(jù)要求的模式是

          A)內(nèi)模式

          B)概念模式

          C)外模式

          D)設(shè)計(jì)模式

          (10)有三個(gè)關(guān)系R、S和T如下:

          則由關(guān)系R和S得到關(guān)系T的操作是

          A)自然連接

          B)交

          C)投影

          D)并

          (11)以下關(guān)于結(jié)構(gòu)化程序設(shè)計(jì)的敘述中正確的是

          A)一個(gè)結(jié)構(gòu)化程序必須同時(shí)由順序、分支、循環(huán)三種結(jié)構(gòu)組成

          B)結(jié)構(gòu)化程序使用goto語(yǔ)句會(huì)很便捷

          C)在C語(yǔ)言中,程序的模塊化是利用函數(shù)實(shí)現(xiàn)的

          D)由三種基本結(jié)構(gòu)構(gòu)成的程序只能解決小規(guī)模的問(wèn)題

          (12)以下關(guān)于簡(jiǎn)單程序設(shè)計(jì)的步驟和順序的說(shuō)法中正確的是

          A)確定算法后,整理并寫(xiě)出文檔,最后進(jìn)行編碼和上機(jī)調(diào)試

          B)首先確定數(shù)據(jù)結(jié)構(gòu),然后確定算法,再編碼,并上機(jī)調(diào)試,最后整理文檔

          C)先編碼和上機(jī)調(diào)試,在編碼過(guò)程中確定算法和數(shù)據(jù)結(jié)構(gòu),最后整理文檔

          D)先寫(xiě)好文檔,再根據(jù)文檔進(jìn)行編碼和上機(jī)調(diào)試,最后確定算法和數(shù)據(jù)結(jié)構(gòu)

          (13)以下敘述中錯(cuò)誤的是

          A) C程序在運(yùn)行過(guò)程中所有計(jì)算都以二進(jìn)制方式進(jìn)行

          B)C程序在運(yùn)行過(guò)程中所有計(jì)算都以十進(jìn)制方式進(jìn)行

          C)所有C程序都需要編譯鏈接無(wú)誤后才能運(yùn)行

          D)C程序中整型變量只能存放整數(shù),實(shí)型變量只能存放浮點(diǎn)數(shù)

          (14)有以下定義:int a; long b; double x,y;則以下選項(xiàng)中正確的表達(dá)式是

          A)a%(int)(x-y)

          B)a=x!=y;

          C)(a*y)%b

          D)y=x+y=x

          (15)以下選項(xiàng)中能表示合法常量的是

          A)整數(shù):1,200

          B)實(shí)數(shù):1.5E2.0

          C )字符斜杠: ‘\’

          D)字符串: "\007"

          (16)表達(dá)式a+=a-=a=9的值是

          A)9

          B)_9

          C)18

          D)0

          (17)若變量已正確定義,在if (W)printf(“%d\n,k”);中,以下不可替代W的是

          A)a<>b+c

          B)ch=get)

          C)a==b+c

          D)a++

          (18)有以下程序

          #include

          main()

          {int a=1,b=0;

          if(!a) b++;

          else if(a==0)if(a)b+=2;

          else b+=3;

          printf(”%d\n”,b);

         。

          程序運(yùn)行后的輸出結(jié)果是

          A)0

          B)1

          C)2

          D)3

          (19)若有定義語(yǔ)句int a, b;double x;則下列選項(xiàng)中沒(méi)有錯(cuò)誤的是

          A)switch(x%2) B)switch((int)x/2.0

          {case 0: a++; break; {case 0: a++; break;

          case 1: b++; break; case 1: b++; break;

          default : a++; b++; default : a++; b++;

          } }

          C)switch((int)x%2) D)switch((int)(x)%2)

          {case 0: a++; break; {case 0.0: a++; break;

          case 1: b++; break; case 1.0: b++; break;

          default : a++; b++; default : a++; b++;

          } }

          (20)有以下程序

          #include

          main()

          {int a=1,b=2;

          while(a<6){b+=a;a+=2;b%二10;}

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

         。

          程序運(yùn)行后的輸出結(jié)果是

          A)5,11

          B)7,1

          C)7,11

          D)6,1

          (21)有以下程序

          #include

          main()

          {int y=10;

          while(y--);

          printf(”Y=%d\n”,Y);

         。

          程序執(zhí)行后的輸出結(jié)果是

          A)y=0

          B)y= -1

          C)y=1

          D)while構(gòu)成無(wú)限循環(huán)

          (22)有以下程序

          #include

          main()

          {char s[」=”rstuv";

          printf(”%c\n”,*s+2);

         。

          程序運(yùn)行后的輸出結(jié)果是

          A)tuv

          B)字符t的ASCII碼值

          C)t

          D)出錯(cuò)

          (23)有以下程序

          #include

          #include

          main()

          {char x[]=”STRING”;

          x[0」=0;x[1]=’\0’;x[2」=’0’;

          printf(”%d %d\n”,sizeof(x),strlen(x));

         。

          程序運(yùn)行后的輸出結(jié)果是

          A)6 1

          B)7 0

          C)6 3

          D)7 1

          (24)有以下程序

          #include

          Int f(int x);

          main()

          {int n=1,m;

          m=f(f(f(n)));printf(”%d\n”,m);

         。

          int f(int x)

          {return x*2;}

          程序運(yùn)行后的輸出結(jié)果是

          A)1

          B)2

          C)4

          D)8

          (25)以下程序段完全正確的`是

          A)int *p; scanf("%d",&p);

          B)int *p; scanf(“%d”,p);

          C)int k, *p=&k; scanf("%d",p);

          D)int k, *p:; *p= &k; scanf(“%d”,p);

          (26)有定義語(yǔ)句:int *p[4];以下選項(xiàng)中與此語(yǔ)句等價(jià)的是

          A)int p[4];

          B)int **p;

          C)int *(p「4」);

          D)int (*p)「4」;

          (27)下列定義數(shù)組的語(yǔ)句中,正確的是

          A)int N=10; B)#define N 10

          int x[N]; int x[N];

          C)int x[0..10]; D)int x[];

          (28)若要定義一個(gè)具有5個(gè)元素的整型數(shù)組,以下錯(cuò)誤的定義語(yǔ)句是

          A)int a[5]=﹛0﹜;

          B)int b[]={0,0,0,0,0};

          C)int c[2+3];

          D)int i=5,d[i];

          (29)有以下程序

          #include

          void f(int *p);

          main()

          {int a[5]={1,2,3,4,5},*r=a;

          f(r);printf(”%d\n”;*r);

         。

          void f(int *p)

          {p=p+3;printf(”%d,”,*p);}

          程序運(yùn)行后的輸出結(jié)果是

          A)1,4

          B)4,4

          C)3,1

          D)4,1

          (30)有以下程序(函數(shù)fun只對(duì)下標(biāo)為偶數(shù)的元素進(jìn)行操作)

          # include

          void fun(int*a;int n)

          {int i、j、k、t;

          for (i=0;i

          {k=i;‘

          for(j=i;ja〔k])k=j;

          t=a〔i];a〔i]=a[k];a〔k]=t;

         。

          }

          main()

          {int aa「10」={1、2、3、4、5、6、7},i;

          fun(aa、7);

          for(i=0,i<7; i++)printf(”%d,”,aa[i]));

          printf(”\n”);

         。

          程序運(yùn)行后的輸出結(jié)果是

          A)7,2,5,4,3,6,1

          B)1,6,3,4,5,2,7

          C)7,6,5,4,3,2,1

          D)1,7,3,5,6;2,1

          (31)下列選項(xiàng)中,能夠滿足“若字符串s1等于字符串s2,則執(zhí)行ST"要求的是

          A)if(strcmp(s2,s1)==0)ST;

          B)if(sl==s2)ST;

          C)if(strcpy(s l ,s2)==1)ST;

          D)if(sl-s2==0)ST;

          (32)以下不能將s所指字符串正確復(fù)制到t所指存儲(chǔ)空間的是

          A)while(*t=*s){t++;s++;}

          B)for(i=0;t[i]=s[i];i++);

          C)do{*t++=*s++;}while(*s);

          D)for(i=0,j=0;t[i++]=s[j++];);

          (33)有以下程序( strcat函數(shù)用以連接兩個(gè)字符串)

          #include

          #include

          main()

          {char a[20]=”ABCD\OEFG\0”,b[]=”IJK”;

          strcat(a,b);printf(”%s\n”,a);

         。

          程序運(yùn)行后的輸出結(jié)果是

          A)ABCDE\OFG\OIJK

          B)ABCDIJK

          C)IJK

          D)EFGIJK

          (34)有以下程序,程序中庫(kù)函數(shù)islower (ch)用以判斷ch中的字母是否為小寫(xiě)字母

          #include

          #include

          void fun(char*p)

          {int i=0;

          while (p[i])

          {if(p[i]==’ ’&& islower(p「i-1」))p[i-1]=p[i-1]-‘a(chǎn)’+‘A’;

          i++;

          }

         。

          main()

          {char s1[100]=”ab cd EFG!”;

          fun(s1); printf(”%s\n”,s1);

         。

          程序運(yùn)行后的輸出結(jié)果是

          A)ab cd EFG!

          B)Ab Cd EFg!

          C)aB cD EFG!

          D)ab cd EFg!

          (35)有以下程序

          #include

          void fun(int x)

          {if(x/2>1)fun(x/2);

          printf(”%d”,x);

          }

          main()

          {fun(7);printf(”\n”);}

          程序運(yùn)行后的輸出結(jié)果是

          A)1 3 7

          B)7 3 1

          C)7 3

          D)3 7

          (36)有以下程序

          #include

          int fun()

          {static int x=1;

          x+=1;return x;

         。

          main()

          {int i;s=1;

          for(i=1;i<=5;i++)s+=fun();

          printf(”%d\n”,s);

         。

          程序運(yùn)行后的輸出結(jié)果是

          A)11

          B)21

          C)6

          D)120

          (37)有以下程序

          #inctude

          #include

          Main()

          {int *a,*b,*c;

          a=b=c=(int*)malloc(sizeof(int));

          *a=1;*b=2,*c=3;

          a=b;

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

          }

          程序運(yùn)行后的輸出結(jié)果是

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

          (38)有以下程序

          #include

          main()

          {int s,t,A=10;double B=6;

          s=sizeof(A);t=sizeof(B);

          printf(“%d,%d\n”,s,t);

         。

          在VC6平臺(tái)上編譯運(yùn)行,程序運(yùn)行后的輸出結(jié)果是

          A)2,4 B)4,4 C)4,8 D)10,6

          (39)若有以下語(yǔ)句

          Typedef struct S

          {int g; char h;}T;

          以下敘述中正確的是

          A)可用S定義結(jié)構(gòu)體變量

          B)可用T定義結(jié)構(gòu)體變量

          C)S是struct類型的變量

          D)T是struct S類型的變量

          (40)有以下程序

          #include

          main()

          {short c=124;

          c=c_______;

          printf(“%d\n”、C);

         。

          若要使程序的運(yùn)行結(jié)果為248,應(yīng)在下劃線處填入的是

          A)>>2 B)|248 C)&0248 D)<

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

          請(qǐng)將每空的正確答案寫(xiě)在答題卡【1】至【15】序號(hào)的橫線上,答在試卷上不得分。

          (1)一個(gè)棧的初始狀態(tài)為空。首先將元素5,4,3,2,1依次入棧,然后退棧一次,再將元素A,B,C,D依次入棧,之后將所有元素全部退棧,則所有元素退棧(包括中間退棧的元素)的順序?yàn)椤?】

          (2)在長(zhǎng)度為n的線性表中,尋找最大項(xiàng)至少需要比較【2】次。

          (3)一棵二叉樹(shù)有10個(gè)度為1的結(jié)點(diǎn),7個(gè)度為2的結(jié)點(diǎn),則該二叉樹(shù)共有【3】個(gè)結(jié)點(diǎn)。

          (4)僅由順序、選擇(分支)和重復(fù)(循環(huán))結(jié)構(gòu)構(gòu)成的程序是【4】程序。

          (5)數(shù)據(jù)庫(kù)設(shè)計(jì)的四個(gè)階段是:需求分析,概念設(shè)計(jì),邏輯設(shè)計(jì)【5】。

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

          #include

          main()

          {int a=200,b=010;

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

          }

          (7)有以下程序

          #include

          main()

          {int x,Y;

          scanf(”%2d%ld”,&x,&y);printf(”%d\n”,x+y);

          }

          程序運(yùn)行時(shí)輸入:1234567程序的運(yùn)行結(jié)果是【7】。

          (8)在C語(yǔ)言中,當(dāng)表達(dá)式值為0時(shí)表示邏輯值“假”,當(dāng)表達(dá)式值為【8】時(shí)表示邏輯值“真”。

          (9)有以下程序

          #include

          main()

          {int i,n[]={0,0,0,0,0};

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

          {n[i]=n[i-1]*3+1; printf(”%d ",n[i]);}

          }

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

          (10)以下fun函數(shù)的功能是:找出具有N個(gè)元素的一維數(shù)組中的最小值,并作為函數(shù)值返回。請(qǐng)?zhí)羁铡?設(shè)N已定義)

          int fun(int x[N])

          {int i,k=0;

          for(i=0;i

          if(x[i]

          return x[k];

          }

          (11)有以下程序

          #include

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

          main()

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

          r=f(r,&n);printf(”%d\n”,*r);

         。

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

          {return(*p>*q)?p:q;}

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

          (12)以下fun函數(shù)的功能是在N行M列的整形二維數(shù)組中,選出一個(gè)最大值作為函數(shù)值返回,請(qǐng)?zhí)羁铡?設(shè)M,. N已定義)

          int fun(int a[N][M))

          {int i,j,row=0,col=0;

          for(i=0;i

          for(j=0;j

          if(a[i][j]>a[row][col]){row=i;col=j;}

          return(【12】):

          }

          (13)有以下程序

          #include

          main()

          {int n[2],i,j;

          for(i=0;i<2;i++)n[i]=0;

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

          for(j=0;j<2;j++)n[j]=n「i」+1;

          printf(”%d\n”,n[1]);

         。

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

          (14)以下程序的功能是:借助指針變量找出數(shù)組元素中最大值所在的位置并輸出該最大值。請(qǐng)?jiān)谳敵稣Z(yǔ)句中填寫(xiě)代表最大值的輸出項(xiàng)。

          #include

          main()

          {int a〔10],*p,*s;

          for(p=a;p-a<10;p++)scanf(”%d”,p);

          for(p=a,s=a;p-a<10;p++)if(*p>*s)S=P;

          printf("max=%d\n”,【14】);

         。

          (15)以下程序打開(kāi)新文件f.txt,并調(diào)用字符輸出函數(shù)將a數(shù)組中的字符寫(xiě)入其中,請(qǐng)?zhí)羁铡?/p>

          #include

          main()

          {【15】*fp;

          char a[5]={’1’,’2’,’3’,’4’,’5’},i;

          fp=fopen(”f .txt”,”w”);

          for(i=0;i<5;i++)fputc(a[i],fp);

          fclose(fp);

         。

          計(jì)算機(jī)二級(jí)C語(yǔ)言筆試歷年真題及答案 2

          一、 選擇題(7分,每小題0.5分)

          1.C語(yǔ)言源程序的基本單位是( )。

          A 過(guò)程 B 函數(shù) C 子程序 D 標(biāo)識(shí)符

          2.下列程序的輸出結(jié)果是( )。

          main( )

          { int a=7,b=5;

          printf("%d ",b=b/a);

          }

          A 5 B 1 C 0 D不確定值

          3.假設(shè)變量a,b均為整型,表達(dá)式(a=5,b=2,a>b?a++:b++,a+b)的值是( )。

          A 7 B 8 C 9 D 2

          4.設(shè)a為int型變量,執(zhí)行下列賦值語(yǔ)句后,a的取值分別是( )。

          a=125.534; a=(int)125.521%4; a=5<<2;

          A 125,31,1 B 125,1,20 C 125,31,20 D 125.534,2,20

          5.設(shè)有如下程序段,下面描述中正確的是 ( )。

          int k=10; while(k=0) k=k-1;

          A 循環(huán)執(zhí)行一次 B循環(huán)是無(wú)限循環(huán) C循環(huán)體語(yǔ)句一次也不執(zhí)行 D循環(huán)體語(yǔ)句執(zhí)行一次

          6.以下程序的輸出結(jié)果為( )。

          int i;

          void prt( )

          { for(i=5;i<8;i++) printf("%c",*);

          printf(" ");

          }

          main( )

          { for(i=5;i<=8;i++) prt( );

          }

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

          7.在C語(yǔ)言程序中,以下說(shuō)法正確的是( )。

          A函數(shù)的定義可以嵌套,但函數(shù)的調(diào)用不可以嵌套

          B函數(shù)的定義不可以嵌套,但函數(shù)的調(diào)用可以嵌套

          C函數(shù)的`定義和函數(shù)的調(diào)用都不可以嵌套

          D函數(shù)的定義和函數(shù)的調(diào)用都可以嵌套

          8.以下函數(shù)調(diào)用語(yǔ)句中含有( )個(gè)實(shí)參。

          func((e1,e2),(e3,e4,e5));

          A 2 B 3 C 5 D 語(yǔ)法錯(cuò)誤

          9.以下程序的輸出結(jié)果為( )。

          #define ADD(x) x*x

          main( )

          { int a=4,b=6,c=7,d=ADD(a+b)*c;

          printf("d=%d",d);

          }

          A d=70 B d=80 C d=140 D d=700

          10.已知職工記錄描述如下,在Turbo C中,系統(tǒng)為變量w分配( )字節(jié)的空間。

          struct worker

          { int no;

          char name[20];

          char sex;

          union

          { int day; int month; int year;}birth;

          } w;

          A 29 B 20 C 25 D 6

          11.設(shè)有以下定義,值為5的枚舉常量是( )。

          enum week{sun,mon=4,tue,wed,thu,fri,sat} w;

          A tue B sat C fri D thu

          12.下面選項(xiàng)中正確的賦值語(yǔ)句是(設(shè) char a[5],*p=a;)( )。

          A p="abcd"; B a="abcd"; C *p="abcd"; D *a="abcd";

          13.設(shè)有以下程序段,則值為6的表達(dá)式是( )。

          struct st { int n; struct st *next;};

          static struct st a[3]={5,&a[1],7,&a[2],9,0 },*p;

          p=&a[0];

          A p++->n B ++p->n C p->n++ D (*p).n++

          14.C語(yǔ)言中的文件類型只有( )。

          A 索引文件和文本文件兩種 B 文本文件一種

          C 二進(jìn)制文件一種 D ASCII碼文件和二進(jìn)制文件兩種

          二、 判斷對(duì)錯(cuò),對(duì)的劃“√”,錯(cuò)的劃“×”(5分,每小題0.5分)

          1.在Turbo C中,整型數(shù)據(jù)在內(nèi)存中占2個(gè)字節(jié)。( )

          2.int i=20;switch(i/10){case 2:printf("A");case 1:printf("B");}的輸出結(jié)果為A。( )

          3.break語(yǔ)句用在循環(huán)體中,可結(jié)束本層循環(huán),continue語(yǔ)句用在循環(huán)體中,可結(jié)束本次循環(huán)。( )

          4.函數(shù)的遞歸調(diào)用不過(guò)是一個(gè)函數(shù)直接或間接地調(diào)用它自身。( )

          5.函數(shù)strlen("ASDFG ")的值是7。( )

          6.通過(guò)return語(yǔ)句,函數(shù)可以帶回一個(gè)或一個(gè)以上的返回值。( )

          7.結(jié)構(gòu)體類型只有一種。 ( )

          8.char *p="girl";的含義是定義字符型指針變量p,p的值是字符串"girl"。( )

          9.若有定義:char *p(char a[10]);則p是函數(shù)名。( )

          10.用fopen("file","r+");打開(kāi)的文件"file"可以進(jìn)行修改。 ( )

          三、 寫(xiě)出下列程序的運(yùn)行結(jié)果(10分,每小題2分)

          1.float average (float array[10])

          { int i;

          float aver,sum=array[0];

          for (i=1;i<10;i++)

          sum=sum+array[i];

          aver=sum/10;

          return(aver);

          }

          main( )

          { float score[10]={89,67.5,78,91,56,82.5,65,70,79,88},aver;

          int i;

          aver=average (score);

          printf (“average score is %5.2f ”,aver);

          }

          2.main( )

          { char a[5]={‘A’,‘B’,‘C’,‘D’,‘E’},*p=a,**pa;

          for(p=0;p

          printf(“%2c”,*p);

          printf(“ ”);

          printf(“%2c ”,**(pa=&p));

          }

          3.main( )

          { int a,b,s=0;

          for(a=1,b=1;a<=100;a++)

          { if(b>=20) break;

          if(b%3==1)

          { b+=3; continue; }

          b-=5;

          }

          printf(“a=%d b=%d ”,a,b);

          }

          4.main()

          { printf(“main( ) :%d ”,fact(5));

          fact(-5);

          }

          fact(int value)

          { int f;

          if(value<0)

          { printf(“Arg error ");

          return(-1);

          }

          else if(value==1||value==0) f=1;

          else f=value*fact(value-1)+1;

          printf(“This called value=%d ”,f);

          return f;

          }

          5.main( )

          { int a=012,b=0x12,k=12;

          char c=‘102’,d=‘ ’;

          printf(“a=%d b=%d k=%d ”,a,b,k);

          printf(“c=%c,d=%c%o ”,c,d,a);

          a=‘A’; c=49;

          printf(“a=%d c=%c ”,a,c);

          }

          四 、閱讀下列程序,在 處填入適當(dāng)內(nèi)容,使程序完整(8分,每個(gè)空1分)

          1.有一個(gè)3*4矩陣,求其中的最大元素。

          max_value( (1) )

          { int i,j,max;

          max=array[0][0];

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

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

          if(array[i][j]>max)

          max=array[i][j];

          (2) ;

          }

          main( )

          { int a[3][4], i,j;

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

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

          (3) ;

          printf(“max value is %d ”,max_value(a));

          }

          2.輸入x、y兩個(gè)整數(shù),按先大后小的順序輸出x、y。

          #include “stdio.h”

          main( )

          { int x,y, *px,*py, (4) ;

          scanf(“%d%d”,&x,&y);

          (5) ; (6) ;

          if(x

          { p=px; px=py; py=p; }

          printf(“x=%d,y=%d ”,x,y);

          printf(“MAX=%d,MIN=%d ”,*px,*py);

          }

          3.用選擇排序法對(duì)任意10個(gè)整數(shù)按照由小到大排序。

          main()

          { int a[11],i,j,k,t;

          printf("Please input 10 numbers: ");

          for(i=1;i<11;i++) scanf("%d",&a[i]);

          printf(" ");

          for(i=1;i<=9;i++)

          { (7) ;

          for(j=i+1; (8) ;j++)

          if(a[j]>a[k]) k=j;

          if(k!=i)

          { t=a[k]; a[k]=a[i]; a[i]=t;}

          }

          printf("The sorted numbers: ");

          for(i=1;i<11;i++) printf("%d ",a[i]);

          }

          答案

          一 、選擇題(7分,每小題0.5分)

          1. B 2. C 3. B 4. B 5. C

          6. A 7. B 8. A 9. A 10. C

          11. A 12. A 13. B 14. D

          二 、判斷對(duì)錯(cuò),對(duì)的劃“√”,錯(cuò)的劃“×”(5分,每小題0.5分)

          1.× 2.× 3.√ 4.√ 5.×

          6.× 7.× 8.× 9.√ 10.√

          三 、寫(xiě)出下列程序的運(yùn)行結(jié)果(10分,每小題2分)

          1. 2. 3.

          4. 5.

          四、 閱讀下列程序,在 處填入適當(dāng)內(nèi)容,使程序完整(8分,每個(gè)空1分)

          1.(1)int array[3][4](int array[][4]) (2)return(max) (3)scanf(“%d”,&a[i][j])

          2.(4)*p (5)px=&x(py=&y) (6)py=&y(px=&x)

          3.(7) (8)

          計(jì)算機(jī)二級(jí)C語(yǔ)言筆試歷年真題及答案 3

          一、 選擇題(24分,每小題2分)

          1.已知函數(shù)fread的調(diào)用形式為fread(buffer,size,count,fp),其中buffer代表的是( )。

          A 存放讀入數(shù)據(jù)項(xiàng)的存儲(chǔ)區(qū) B 存放讀入數(shù)據(jù)的地址或指向此地址的指針

          C 一個(gè)指向所讀文件的文件指針 D 一個(gè)整形變量,代表要讀入的數(shù)據(jù)項(xiàng)總數(shù)

          2.以下程序的輸出結(jié)果為( )。

          main( )

          { int i=010,j=10;

          printf("%d,%d ",i++,j--);

          }

          A 11,9 B 9,10 C 8,10 D 9,9

          3.設(shè)a為int型變量,執(zhí)行下列賦值語(yǔ)句后,a的取值分別是( )。a=125.534;a=20.0/3;a=(int)125.521%4;a=5<<2;

          A 125,6,31,1 B 125,6,1,20 C 125,6.666666,31,20 D 125.534,6.666666,2,20

          4.設(shè)i和k都是int類型,則for循環(huán)語(yǔ)句( )。

          for(i=0,k=-1;k=1;i++,k++) printf("****");

          A 循環(huán)結(jié)束的條件不合法 B 循環(huán)體一次也不執(zhí)行 C 循環(huán)體只執(zhí)行一次 D 是無(wú)限循環(huán)

          5.以下程序的輸出結(jié)果為( )。

          main( )

          { char c;

          int i;

          for(i=65;i<68;i++)

          { c=i+32;

          switch(c)

          { case a:case b:case c:printf("%c,",c);break; default:printf("end");}

          }

          }

          A a,b,c,end B a,a,a,end C a,a,a, D a,b,c,

          6.函數(shù)調(diào)用語(yǔ)句:fseek(fp,-10L,2);的含義是( )。

          A 將文件位置指針從文件末尾處向文件頭的方向移動(dòng)10個(gè)字節(jié)

          B 將文件位置指針從當(dāng)前位置向文件頭的方向移動(dòng)10個(gè)字節(jié)

          C 將文件位置指針從當(dāng)前位置向文件末尾方向移動(dòng)10個(gè)字節(jié)

          D 將文件位置指針移到距離文件頭10個(gè)字節(jié)處

          7.以下程序的.輸出結(jié)果為( )。

          main( )

          { char s1[40]="country",s2[20]="side";

          int i=0,j=0;

          while(s1[i]!=) i++;

          while(s2[j]!=) s1[i++]=s2[j++];

          s1[i]=0;

          printf("%s ",s1);

          }

          A side B country C sidetry D countryside

          8.下列說(shuō)法不正確的是( )。

          A 主函數(shù)main中定義的變量在整個(gè)文件或程序中有效

          B 不同函數(shù)中,可以使用相同名字的變量

          C 形式參數(shù)是局部變量

          D 在一個(gè)函數(shù)內(nèi)部,可以在復(fù)合語(yǔ)句中定義變量,這些變量只在本復(fù)合語(yǔ)句中有效

          9.在下列程序段中,枚舉變量 c1的值是( )。

          enum color { red,yellow,blue=4,green,white}c1; c1=yellow; c1=white;

          A 1 B 3 C 5 D 6

          10.設(shè)有說(shuō)明 int (*ptr)();其中標(biāo)識(shí)符ptr是( )。

          A 是一個(gè)指向整形變量的指針 B 是一個(gè)指針,它指向一個(gè)函數(shù)值是int的函數(shù)

          C 是一個(gè)函數(shù)名 D定義不合法

          11.定義由n個(gè)指向整形數(shù)據(jù)的指針組成的數(shù)組p,其正確的方式為( )。

          A int p; B int (*p)[n]; C int *p[n]; D int (*p)( );

          12.具有相同類型的指針類型變量p與數(shù)組a,不能進(jìn)行的操作是( )。

          A p=a; B *p=a[0]; C p=&a[0]; D p=&a;

          二 、判斷對(duì)錯(cuò),對(duì)的劃“√”,錯(cuò)的劃“×”(20分,每小題2分)

          1.參加位運(yùn)算的數(shù)據(jù)可以是任何類型的數(shù)據(jù)。( )

          2.若有定義和語(yǔ)句:int a;char c;float f;scanf("%d,%c,%f",&a,&c,&f);若通過(guò)鍵盤(pán)輸入:10,A,12.5,則a=10,c=‘A’,f=12.5。( )

          3.C語(yǔ)言把文件看作是一個(gè)字符(字節(jié))的序列。( )

          4.若有宏定義:#define S(a,b) t=a;a=b;b=t由于變量t沒(méi)定義,所以此宏定義是錯(cuò)誤的。( )

          5.在Turbo C中,下面的定義和語(yǔ)句是合法的:file *fp;fp=fopen("a.txt","r");( )

          6.若有定義:char s[ ]="china";則Turbo C系統(tǒng)為數(shù)組s開(kāi)辟6個(gè)字節(jié)的內(nèi)存單元。( )

          7.若有定義和語(yǔ)句:int a[3][3]={{3,5},{8,9},{12,35}},i,sum=0;for(i=0;i<3;i++) sum+=a[i][2-i];則sum=21。( )

          8.若有定義和語(yǔ)句:struct student { int num; char name[10]; float score;} s[5]={{1,"lili",98.5},{9,"xiaohua",66}},*p=s;printf("%d",*p++);輸出結(jié)果是1。( )

          9.在程序中定義了一個(gè)結(jié)構(gòu)體類型后,可以多次用它來(lái)定義具有該類型的變量。( )

          10.在Turbo C中,此定義和語(yǔ)句是合法的:enum aa{ a=5,b,c}bb;bb=(enum aa)5;( )

          三 、寫(xiě)出下列程序的運(yùn)行結(jié)果(36分,每小題6分)

          1.main( )

          { int i=29,j=6,k=2,s;

          s=i+i/j%k-9;

          printf(“s=%d ”,s);

          }

          2.main( )

          { int x=31,y=2,s=0;

          do

          { s-=x*y;

          x+=2;

          y-=3;} while( x%3==0);

          printf(“x=%d y=%d s=%d ”,x,y,s);

          }

          3.main( )

          { int a[6]={10,20,30,40,50,60},i;

          invert(a,0,5);

          for(i=0;i<6;i++) printf(“%d,”,a[i]);

          printf(“ ”);

          }

          invert(int s[ ],int i,int j)

          { int t;

          if(i

          { invert(s,i+1j-1);

          t=s[i];s[i]=s[j];s[j]=t;

          }

          }

          4.#include

          main()

          { char str[ ]=“The C program”,c;

          int i;

          for(i=2;(c=str[i])!=‘’;i++)

          { switch(c)

          { case ‘g’: ++i; break;

          case ‘o’: continue;

          default: printf(“%c”,c); continue;

          }

          printf(“*”);

          }

          printf(“ ”);

          }

          5.struct w

          { char low;

          char high;

          };

          union u

          { struct w byte;

          short word;

          }uw;

          main( )

          { int result;

          uw.word=0x1234;

          printf(“word value:%04x ”,uw.word);

          printf(“high byte:%02x ”,uw.byte.high);

          printf(“l(fā)ow byte:%02x ”,uw.byte.low);

          uw.byte.low=0x74;

          printf(“word value:%04x ”,uw.word);

          result=uw.word+0x2a34;

          printf(“the result:%04x ”,result);

          }

          6.main()

          { char *s2=“I love China!”,**s1=&s2;

          char *s3,c,*s4=“w”;

          s3=&c;

          *s3=‘H’;

          s2=s2+2;

          printf(“%s %c %s %c ”,s2,*s3,s4,**s1);

          }

          四、 閱讀下列程序,在 處填入適當(dāng)內(nèi)容,使程序完整(20分,每個(gè)空2分)

          1. 百馬百擔(dān)問(wèn)題:有100匹馬,馱100擔(dān)貨,大馬馱3擔(dān),中馬馱2擔(dān),兩匹小馬馱1擔(dān),問(wèn)大、中、小馬各多少匹?

          main( )

          { int hb,hm,hl,n=0;

          for(hb=0;hb<=100;hb+= (1) )

          for(hm=0;hm<=100-hb;hm+= (2) )

          { hl=100-hb- (3) ;

          if(hb/3+hm/2+2* (3) ==100)

          { n++;

          printf("hb=%d,hm=%d,hl=%d ",hb/3,hm/2,2*hl);

          }

          }

          printf("n=%d ",n);

          }

          2.用“起泡法”對(duì)輸入的10個(gè)字符排序后按從小到大的次序輸出。

          #define N 10

          char str[N];

          main()

          { int i,flag;

          for(flag=1;flag==1;)

          { scanf("%s",str);

          flag=0;

          printf(" ");

          }

          sort(___(4)___);

          for(i=0;i

          printf("%c",str[i]);

          printf(" ");

          }

          sort(char str[N])

          { int i,j;

          char t;

          for(j=1;j

          for(i=0;(i

          if(str[i]>str[i+1])

          { t=str[i];

          ____(5)____;

          ____(6)____;

          }

          }

          3.以下程序是一個(gè)函數(shù),功能是求二階矩陣(m行n列矩陣)的所有靠外側(cè)的各元素值之和。(本程序中二階矩陣用一維數(shù)組來(lái)表示。)

          例如,矩陣為:

          3 0 0 3

          2 5 7 3

          1 0 4 2

          則所有靠外側(cè)的各元素值之和為3+0+0+3+2+3+1+0+4+2=18。

          add(int m,int n,int arr[])

          { int i,j,sum=0;

          for(i=0;i

          for(j=0;j

          sum=sum+ (7) ;

          for(j=0;j

          for(i=1; (8) ;i++)

          sum=sum+arr[i*n+j];

          return(sum);

          }

          4.用指針作函數(shù)參數(shù),編程序求一維數(shù)組中的最大和最小的元素值。

          #define N 10

          main()

          { void maxmin(int arr[],int *pt1,int *pt2,int n);

          int array[N]={10,7,19,29,4,0,7,35,-16,21},*p1,*p2,a,b;

          p1=&a; p2=&b;

          maxmin(array,p1,p2,N);

          printf("max=%d,min=%d",a,b);

          }

          void maxmin(int arr[],int *pt1,int *pt2,int n)

          { int i;

          *pt1=*pt2=arr[0];

          for(i=1;i

          { if(arr[i]>*pt1) (9) ;

          if(arr[i]<*pt2) (10) ;

          }

          }

          答案

          一 、選擇題(24分,每小題2分)

          1.( B ) 2.( C ) 3.( B ) 4.( D ) 5.( D ) 6.( A )

          7.( D ) 8.( A ) 9.( D ) 10.( B ) 11.( C ) 12.( D )

          二 、判斷對(duì)錯(cuò),對(duì)的劃“√”,錯(cuò)的劃“×”(20分,每小題2分)

          1.( × ) 2.( √ ) 3.( √ ) 4.( × ) 5.( × )

          6.( √ ) 7.( √ ) 8.( × ) 9.( √ ) 10.( √ )

          三 、寫(xiě)出下列程序的運(yùn)行結(jié)果(36分,每小題6分)

          1. s=20 2.x=35 y=-4 s=-29 3.60,50,40,30,20,10,

          4.e C pr*am 5.word value:1234 6.love China! H w l

          high byte:12

          low byte:34

          word value:1274

          the result:3ca8

          四 、閱讀下列程序,在 處填入適當(dāng)內(nèi)容,使程序完整(20分,每個(gè)空2分)

          1.(1) 3 (2) 2 (3)hm hl

          2.(4) str (5) str[i]=str[i+1] (6) str[i+1]=t

          3.(7) arr[i*n+j](或者arr[i*10+j])

          (8) i

          4.(9) *ptr1=arr[i] (10) *ptr2=arr[i]

        【計(jì)算機(jī)二級(jí)C語(yǔ)言筆試歷年真題及答案】相關(guān)文章:

        計(jì)算機(jī)二級(jí)考試C語(yǔ)言歷年真題及答案解析03-10

        計(jì)算機(jī)二級(jí)考試C語(yǔ)言歷年真題09-26

        計(jì)算機(jī)二級(jí)C語(yǔ)言真題及答案09-26

        四川省計(jì)算機(jī)二級(jí)C語(yǔ)言筆試真題及答案03-29

        2017年計(jì)算機(jī)二級(jí)c語(yǔ)言題庫(kù)歷年真題03-26

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

        2016年計(jì)算機(jī)二級(jí)C語(yǔ)言考試真題及答案03-05

        2024年計(jì)算機(jī)二級(jí)c語(yǔ)言考試真題及答案09-25

        3月計(jì)算機(jī)等級(jí)考試二級(jí)c筆試真題01-22

        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码
      3. <sub id="h4knl"><ol id="h4knl"></ol></sub>
        <sup id="h4knl"></sup>
          <sub id="h4knl"></sub>

          <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
          1. <strong id="h4knl"></strong>

          2. 在线亚洲观看精品过产 | 亚洲欧美另类国产 | 精品国精品自拍自在线 | 在线精品三级视频在线网 | 日韩AV在线免费观看 | 日韩精品一区二区三区在线视频放 |