網(wǎng)站首頁(yè)
分類(lèi)導(dǎo)航
試題中心
下載中心
英語(yǔ)學(xué)習(xí)
繽紛校園
考試論壇
網(wǎng)站留言
客服中心
 05年9月等級(jí)考試二級(jí)C語(yǔ)言考前密卷(七)
【字體:
05年9月等級(jí)考試二級(jí)C語(yǔ)言考前密卷(七)
http://m.1glr.cn 來(lái)源:ChinaITLab 點(diǎn)擊: 更新:2005-9-15

     (28)以下選項(xiàng)中,非法的字符常量是 ______。
  A)'\t'    B)'\17'      C)"\n"      D)'\xaa'
  答案:C
  評(píng)析:C語(yǔ)言中字符常量是以單引號(hào)括起來(lái)的單個(gè)字符,或?yàn)橐?\"與三位八進(jìn)制數(shù)值或兩位十六進(jìn)制數(shù)值代替單個(gè)字符。
  
  (29)以下程序的輸出結(jié)果是______ 。
  #include<stdio.h>
  main()
  {
  int a=200;
  #define a lOO
  printf("%d",a);
  #undef a
  printf ("%dt",a);
  }
  A)200 100    B)100 100      C)100 200      D)200 200
  答案:C
  評(píng)析:#define宏名的有效范圍為定義命令之后到本源文件結(jié)束,可以在程序中使用#undef命令終止宏定義的作用域。本題由于#undef的作用,使a的作用范圍在#define a 100到#undefa之間,故答案為c。
  
  (30)若有說(shuō)明:int i,j=2,*p=&i;,則能完成i=j賦值功能的語(yǔ)句是______。
  A)i=*p;    B)*p=*&j;     C)i=&j;      D)i=**p;
  答案:B
  評(píng)析:指針是一種用來(lái)存放變量地址的特殊變量。本題中指針變量p用于存放整型變量i的地址,改變*p的值即為改變i的值。又因?yàn)?&"和"∥兩個(gè)運(yùn)算符的優(yōu)先級(jí)別相同,按自右而左的方向結(jié)合,所以。&j先進(jìn)行&j運(yùn)算,得j的地址,再進(jìn)行+運(yùn)算,取所得地址里面的值,故t&j與i等價(jià)。
  
  (31)假定int類(lèi)型變量占用兩個(gè)字節(jié),若有定義:int x[10]={0,2,4};,則數(shù)組x在內(nèi)存中所占字節(jié)數(shù)是______。
  A)3       B)6         C)10        D)20
  答案:D
  評(píng)析:當(dāng)數(shù)組定義后,系統(tǒng)就為其分配內(nèi)存空間,而不論其中有沒(méi)有內(nèi)容。因此,本題中數(shù)組x[10]不論是否為其元素初始化,它所分配的存儲(chǔ)空間仍為2+10=20個(gè)字節(jié)。
  
  (32)執(zhí)行以下的程序段后,m的值是______。
  int a[2][3]={{l,2,3},{4,5,6}};
  int m,*p;
  p=&a[0][0];
  m=p[41;
  A)4       B)5         C)3         D)不確定
  答案:B
  評(píng)析:程序中定義了一個(gè)指向整型變量的指針變量,并對(duì)其賦值為二維整型數(shù)組a的首元素的地址。P[4]等價(jià)于*(p+4),即二維數(shù)組a中第四個(gè)元素的值,而a是一個(gè)2*3的二維數(shù)組,其第四個(gè)元素為a[1][1],即5。
  
  (33)以下程序的輸出結(jié)果是______。
  main()
  {int i,a[10];
  for(i=9;i>=O;i--) a[i]=lO-i;
  printf("%d%d%d",a[2],a[5],a[8]);
  }
  A)258      B)74l        C)852        D)369
  答案:C
  評(píng)析:在本題運(yùn)行時(shí)主要注意的是當(dāng)i=9時(shí),a[i]=10-9=1;i=8時(shí),a[i]=10-8=2;i=7時(shí),a[i]=10-7=3:……依此類(lèi)推,,直到i=0時(shí),a[i]=10-0=10;此時(shí),i的值已變?yōu)椋?,判斷for的循環(huán)條件,不成立,然后輸出a[2],a[5],a[8]分別為8,5,2。
  
  (34)下面程序的輸出結(jié)果為_(kāi)_____ 。
  #include<string.h>
  main()
  {
  char pl[7]="abc",p2[]="ABC",str[50]= "xyz";
  strcpy(str,strcat(pl,p2));
  printf("%s",str);
  }
  A)xyzabcABC  B)abcABC       C)xyzabc      D)xyzABC
  答案:B
  評(píng)析:strcpy(strl,s1):作用是將字符串s1拷貝到字符數(shù)組strl中去。strcat(字符數(shù)組1,字符數(shù)組2):把。字符串2接到字符串l的后面,結(jié)果放在字符數(shù)組1中,函數(shù)調(diào)用后返回字符數(shù)組l的地址。
  本題定義了三個(gè)字符數(shù)組pl,p2,str,strcat(p1,p2)函數(shù)的作用是將字符串?dāng)?shù)組p2接到字符串p1的后面,結(jié)果放在字符數(shù)組p1,再通過(guò)sffcpy()函數(shù)將該字符串拷貝到str數(shù)組中,原str數(shù)組中的字符串xyz被覆蓋,因此打印輸出字符串str即可得到abcABC。
  
  (35)以下數(shù)組定義中不正確的是______。
  A)int a[2Ⅱ3];        B)int b[][3]={0,1,2);
  C)int c[100][100]={0};    D)int d[3][]={{l,2},{l,2,3},{1,2,3,4}};
  答案:D
  評(píng)析:一維數(shù)組的定義方式為:
  類(lèi)型說(shuō)明符數(shù)組名[常量表達(dá)式];
  選項(xiàng)A符合此定義形式,正確;c語(yǔ)言中多維數(shù)組賦初值時(shí)可以部分賦值,也可以不指定除第一維以外的其它維的大小,故選項(xiàng)c正確;另外,如果對(duì)全部數(shù)組元素都賦初值,則定義數(shù)組時(shí)對(duì)第一維的長(zhǎng)度可以不指定,但第二維的長(zhǎng)度不能省,所以選項(xiàng)B正確,而選項(xiàng)D是錯(cuò)誤的。
  
  (36)以下程序的輸出結(jié)果是______。
  main()
  { jnt a[4][4]:{{1,3,5},{2,4,6},{3,5,7}};
  printf("%d%d%d%d\n",a[0][3],a[1][2],a[2][1],a[3][0]);
  }
  A)0650     B)1470       C)5430       D)輸出值不定
  答案:A
  評(píng)析:對(duì)未給出初始值的整數(shù)數(shù)組元素,被缺省初始化為零。
  
  (37)在說(shuō)明語(yǔ)句:int *f();中,標(biāo)識(shí)符f代表的是______。
  A)一個(gè)用于指向整型數(shù)據(jù)的指針變量  B)一個(gè)用于指向一維數(shù)組的行指針
  C)一個(gè)用于指向函數(shù)的指針變量    D)一個(gè)返回值為指針型的函數(shù)名
  答案:D
  評(píng)析:帶回指針值的函數(shù),其一般定義形式為:
  類(lèi)型標(biāo)識(shí)符 *函數(shù)名(參數(shù)表);
  例如:int *f(x,y);
  其中,f是函數(shù)名,調(diào)用它以后能得到一個(gè)指向整型數(shù)據(jù)的指針(地址),x,y是函數(shù)f的形參。在f的兩側(cè)分別為。運(yùn)算符和()運(yùn)算符,而()優(yōu)先級(jí)高于s,因此f先與()結(jié)合,顯然是函數(shù)形式。這個(gè)函數(shù)前面有一個(gè)。,表示此函數(shù)是指針型函數(shù)(函數(shù)值是指針)。前面的int表示返回的指針指向整型變量。
  
  (38)以下程序的輸出結(jié)果是______。
  main()
  { char st[20]= "hello\0\t\\";
  printf("%d%d\n",strlen(st),sizeof(st));
  }
  A)99       B)520       C)1320       D)2020
  答案:B
  評(píng)析:c語(yǔ)言中字符串是以'\0'字符結(jié)束的,且strlen()函數(shù)計(jì)算的是'\0'字符前的所有字符的個(gè)數(shù)。本題中strlen(st)應(yīng)為5。數(shù)組定義以后系統(tǒng)就為其分配相應(yīng)大小的內(nèi)存空間,而不論其中有沒(méi)有內(nèi)容。sizeof()函數(shù)是計(jì)算變量或數(shù)組的所分配到的內(nèi)存空間的大小。所以本題的sizeof(st)為20。
  
  (39)下面程序運(yùn)行后的輸出結(jié)果是______。
  int d=1:
  fun(int p)
  { static int d=5;d+=p;
  printf("%d",d);return d;
  }
  main()
  {int a=3;printf("%d\n",fun(a+fun(d)));}
  A)6 9 9     B)6 6 9       C)6 15 15      D)6 6 15
  答案:C
  評(píng)析:靜態(tài)局部變量在編譯時(shí)賦初值,即只賦初值一次,在程序運(yùn)行時(shí)它已有初值。以后每次調(diào)用時(shí)不再重新賦初值而只是保留上次函數(shù)調(diào)用結(jié)束時(shí)的值,而對(duì)自動(dòng)變量賦初值,不是在編譯時(shí)進(jìn)行的,而在函數(shù)調(diào)用時(shí)進(jìn)行,每調(diào)用一次函數(shù)重新給一次初值,相當(dāng)于執(zhí)行一次賦值語(yǔ)句。
  本題在程序開(kāi)頭定義了全局變量d并賦初值1,在被調(diào)函數(shù)fun()中,定義了靜態(tài)局部變量d,初值為5。在第一次調(diào)用函數(shù)fun時(shí),d初值為5,p由主函數(shù)傳遞過(guò)來(lái)的值為1,則d=d+p=5+l=6,由于d是靜態(tài)局部變量,在函數(shù)調(diào)用結(jié)束后,它仍保留d=6。再次調(diào)用fun函數(shù),d的初值為6,而由主函數(shù)傳遞的p的值為9,則此時(shí)d=d+p=6+9=15,最后打印輸出d的值并返回主函數(shù)。
  
  (40)以下選項(xiàng)中,不能正確賦值的是______。
  A)char s1[10];sl="chest";    B)char s2[]。{'C','t','e','s','t');
  C)char s3[20]= "Chest";    D)char*s4="Ctest\n"'
  答案:A
  評(píng)析:c語(yǔ)言中不能將字符串常量直接賦給數(shù)組。但在賦初值時(shí)可以。
  
  (41)以下程序輸出正確的是______。
  alnovep(int *p,int(*a)[3],int n)
  {int i,j;
  for(i=0;i<n;i++)
  for(j=0 ;j<n;j++){ *p=a[i][j];p++;}
  }
  main()
  {int *p,a[3][3]={{1,3,5},{2,4,6}};
  p=(int*)malloc(100);
  amovep(p,a,3);
  printf("%d%d\n",p[2],p[5]);free(p);
  }
  A)56       B)25        C)34         D)程序錯(cuò)誤
  答案:A
  評(píng)析:本題main函數(shù)中定義了指針p和二維數(shù)組a,通過(guò)函數(shù)amovep將數(shù)組的值存入指針p所指向的存儲(chǔ)單元中,a的各元素分別為:a[0][0]=l,a[0][1]=3,a[0][2]=5,a[1][0]=2,a[l][1]=4,a[1][2]=6,a[2][O]=0,a[2][1]=0,a[2][2]=0a
  通過(guò)malloc()函數(shù)給指針?lè)峙鋬?nèi)存空間,free()函數(shù)用于釋放指針變量所用內(nèi)存空間。在主函數(shù)中通過(guò)amovep(p,a,3)調(diào)用函數(shù)amovep,使得實(shí)參p與形參p,實(shí)參數(shù)組a與形參中指向數(shù)組的指針變量共用同一存儲(chǔ)空間。最后輸出p[2],p[5]為56。
  
  (42)下面程序的輸出結(jié)果是______。
  #define a 121
  const b=12:
  enum c{a1,a2};
  main()
  {
  printf("%d,%d,%d.",sizeOf(a),sizeOf(b),sizeof(enum C));
  }
  A)121,0,4   B)2,2,2      C)0,2,4      D)0,2,2
  答案:B
  評(píng)析:sizeof函數(shù)是取變量所占的存儲(chǔ)空間的字節(jié)數(shù),標(biāo)識(shí)a代表常量121;const b=12;,其中數(shù)據(jù)類(lèi)型可以缺省,默認(rèn)為整型;enum c{al,a2};定義了一個(gè)枚舉類(lèi)型enum c,al,a2為枚舉元素,在c編譯時(shí),對(duì)枚舉元素按常量處理,它們的值按定義順序依次為0,1。因此它們的字節(jié)數(shù)均為2,2,2。
  
  (43)以下程序的輸出結(jié)果是______。
  struct HAR
  {int x,y;struct HAR *p;} h[2];
  main()
  { h[0].X=1; h[O].y=2;
  h[1].x=3;h[1].y=4;
  h[0].p=&h[1];h[1].p=h;
  printf("%d%d\n",(h[O].p)->x,(h[1].p)->y);
  }
  A)12       B)23         C)14         D)32
  答案:D
  評(píng)析:本題中是一個(gè)含有兩個(gè)結(jié)點(diǎn)的循環(huán)鏈表。
  c語(yǔ)言中結(jié)構(gòu)體的定義為:.
  struct結(jié)構(gòu)體類(lèi)型名
  {
  成員項(xiàng)表:
  };
  
  (44)變量a所占的內(nèi)存字節(jié)數(shù)是______ 。
  A)4       B)5          C)6          D)8
  Union U
  { char st[4];
  Int i:
  Long l;
  };
  Struct A
  { int c;
  Union U u;
  }a;
  答案:C
  評(píng)析:結(jié)構(gòu)體變量所占內(nèi)存長(zhǎng)度是各成員占內(nèi)存長(zhǎng)度之和,而共用體變量所占的內(nèi)存長(zhǎng)度等于最長(zhǎng)的成員的長(zhǎng)度。本題結(jié)構(gòu)體變量a中成員c為整型占2個(gè)字節(jié),共用體變量u最大長(zhǎng)度為4個(gè)字節(jié),故選C。
  
  (45)以下程序的結(jié)果是______。
  int a,b;
  void fun()
  { a=100;b=200;)
  main()
  {int a=5,b=7;
  fun();
  printf("%d%d\n",a,b);
  }
  A)100200    B)57         C)200100      D)75
  答案:B
  評(píng)析:全程變量是可以在子函數(shù)中對(duì)其值作改變,且它也可作為函數(shù)間的值傳遞。但當(dāng)函數(shù)或子函數(shù)中定義了與全程變量名稱相同的局部變量,則全程變量將被屏蔽。
  
  (46)以下程序的輸出結(jié)果是______。
  #define M(x,y,z) x*y+z
  main()
  { int a=l,b=2,c=3;
  printf("%d\n",M(a+b,b+c,c+a));
  }
  A)19      B)17         C)15        D)12
  答案:D
  評(píng)析:c語(yǔ)言的宏定義包括不帶參數(shù)的宏定義與帶參數(shù)的宏定義。本題為帶參數(shù)的宏定義,其形式為:#define宏名(形參表) 字符串,本題的M(a十b,b+c,c+a)被字符串a(chǎn)+b*b+c+c+a代替。
  
  (47)若有以下說(shuō)明和語(yǔ)句:
  struct st
  {int n;char *ch;);
  struct st a[3]={5,"abc",7,"def',9,"ghK"},*p=a;則值為6的表達(dá)式是______。
  A)p++ ->n    B)p一>n++      C)(*p).n++   D)+十p->n
  答案:D
  評(píng)析:根據(jù)結(jié)構(gòu)變量的存儲(chǔ)特點(diǎn),p+l意味著增加地址值為結(jié)構(gòu)體數(shù)組a的一個(gè)元素所占的字節(jié)數(shù),'即p++使p由a[0]指向a[1]起始地址。本題++p>n得到p指向的結(jié)構(gòu)體變量中成員n的值使之加l。因?yàn)閜指向數(shù)組a起始地址,p->n的值為5,再執(zhí)行自加l運(yùn)行,結(jié)果為6。
  
  (48)整型變量x和Y的值相等,且為非O值,則以下選項(xiàng)中結(jié)果為0的表達(dá)式是______。
  A)x||Y     B)X|Y        C)X&Y        D)X^Y
  答案:D
  評(píng)析:"‖"為或運(yùn)算符,當(dāng)其左右表達(dá)式中只要一個(gè)為非零則整個(gè)表達(dá)式的值1。︱是按位或,&是按位與,^是按位異或,這三位運(yùn)算符是按值的二進(jìn)制位來(lái)比較的。
  
  (49)C語(yǔ)言中,組成數(shù)據(jù)文件的成分是______。
  A)記錄    B)數(shù)據(jù)行       C)數(shù)據(jù)塊      D)字符(字節(jié))序列
  答案:D
  評(píng)析:c語(yǔ)言中的文件是流式文件。流式文件是一種無(wú)結(jié)構(gòu)文件,即整個(gè)文件是一串字符流或二進(jìn)制流。文件的存取以字符或字節(jié)為單位。
  
  (50)下面的程序執(zhí)行后,文件test.t中內(nèi)容是______。
  #include<stdio.h>
  void fun(char *fname,char *st)
  { FILE *myf;int i;
  myf=fopen(fname, "w");
  for(i=0;i<strlen(st);i++)fputc(st[i],myf);
  fclose(myf);
  }
  main()
  {fun("test.t","new world");fun("test.t","hello,");}
  A)hello,  B)new worldhello C)new world  D)hello,rid
  答案:A
  評(píng)析:c語(yǔ)言中文件有文本文件與二進(jìn)制文件,對(duì)文件的使用前必須先打開(kāi),打開(kāi)方式有只讀、寫(xiě)入、讀寫(xiě)等方式。
  
  二、填空題(每空2分,共40分)
  
  請(qǐng)將每一個(gè)空的正確答案寫(xiě)在答題卡的【1】至【20】序號(hào)的橫線上,答在試卷上不得分。
  
  (1)實(shí)現(xiàn)算法所需的存儲(chǔ)單元多少和算法的工作量大小分別稱為算法的 【1】  。
  答案:【1】空間復(fù)雜度和時(shí)間復(fù)雜度
  評(píng)析:算法的復(fù)雜性是指對(duì)一個(gè)在有限步驟內(nèi)終止算法和所需存儲(chǔ)空間大小的估計(jì)。算法所需存儲(chǔ)空間大小是算法的空間復(fù)雜性,算法的計(jì)算量是算法的時(shí)間復(fù)雜性。
  
  (2)數(shù)據(jù)結(jié)構(gòu)包括數(shù)據(jù)的邏輯結(jié)構(gòu)、數(shù)據(jù)的 【2】 以及對(duì)數(shù)據(jù)的操作運(yùn)算。
  答案:【2】存儲(chǔ)結(jié)構(gòu)
  評(píng)析:數(shù)據(jù)結(jié)構(gòu)包括3個(gè)方面,即數(shù)據(jù)的邏輯結(jié)構(gòu)、數(shù)據(jù)的存儲(chǔ)結(jié)構(gòu)及對(duì)數(shù)據(jù)的操作運(yùn)算。
  
  (3)一個(gè)類(lèi)可以從直接或間接的祖先中繼承所有屬性和方法。采用這個(gè)方法提高了軟件的  【3】 。
  答案:【3】可重用性
  評(píng)析:繼承的優(yōu)點(diǎn):相似的對(duì)象可以共享程序代碼和數(shù)據(jù)結(jié)構(gòu),從而大大減少了程序中的冗余,提高軟件的可重用性。
  
  (4)面向?qū)ο蟮哪P椭,最基本的概念是?duì)象和  【4】 。
  答案:【4】類(lèi)
  評(píng)析:面向?qū)ο竽P椭,最基本的概念是?duì)象和類(lèi)。對(duì)象是現(xiàn)實(shí)世界中實(shí)體的模型化;將屬性集和方法集相同的所有對(duì)象組合在一起,可以構(gòu)成一個(gè)類(lèi)。
  
  (5)軟件維護(hù)活動(dòng)包括以下幾類(lèi):改正性維護(hù)、適應(yīng)性維護(hù)、 【5】 維護(hù)和預(yù)防性維護(hù)。
  答案:【5】完善性
  評(píng)析:軟件維護(hù)活動(dòng)包括以下幾類(lèi):改正性維護(hù)、適應(yīng)性維護(hù)、完善性維護(hù)和預(yù)防性維護(hù)。完善性維護(hù)是指為了滿足用戶對(duì)軟件提出的新功能與性能要求,需要修改或再開(kāi)發(fā)軟件,以擴(kuò)充軟件功能、增強(qiáng)軟件性能、改進(jìn)加工效率、提高軟件的可維護(hù)性。
  
  (6)語(yǔ)句:X++;、++X;、X=X+1;、X=l+X;,執(zhí)行后都使變量X中的值增l,請(qǐng)寫(xiě)出一條同一功能的賦值語(yǔ)句(不得與列舉的相同) 【6】  。
  答案:【6】X+=1:
  評(píng)析:在c語(yǔ)言中使變量增l的方法有:自增運(yùn)算符與賦值語(yǔ)句。其中自增運(yùn)算符有前置與后置方式,賦值語(yǔ)句也有兩種類(lèi)型。
  本題中的主要增l方式有:x++;、++x;、X=X+I;、x=1+x;、x+=l;。
  
  (7)設(shè)Y是int型變量,請(qǐng)寫(xiě)出判斷Y為奇數(shù)的關(guān)系表達(dá)式  【7】
  答案:【7】Y%2==1 或Y%2!=0
  評(píng)析:判斷變量是否為奇數(shù)可以用變量與2取模,判斷結(jié)果是為1或不為0。本題具體做法如下:Y%2==1或Y%2 1=0。
  
  (8) 以下程序的輸出是 【8】  。
  main()
  {
  char strl[]="How do you do",*pl=strl:
  strcpy(strl+strlen(strl)/2,"es she");
  printf("%s\n",p1);
  }
  答案:【8】How does she
  評(píng)析:strcpy(strl,s1):字符串拷貝函數(shù),作用是將字符串s1拷貝到字符數(shù)組strl中去。strlen(str):測(cè)試字符串str的長(zhǎng)度,函數(shù)的值為字符串中實(shí)際長(zhǎng)度,不包括'\O'在內(nèi)。本題中strlen(strll的值為13,則strcpy(strl+strlen(strl)/2,"es she",);相當(dāng)于strcpy(strl+6,"es she");,因此可得答案為How does she。
  
  (9)以上程序運(yùn)行后的輸出結(jié)果是 【9】   。
  main()
  {int i=10,J=0;
  do
  {j=j+i;i--;}
  while(i>2);
  printf("%d\n",j);
  }
  答案:【9】52
  評(píng)析:do...while語(yǔ)句的形式為:
  do
  {
  語(yǔ)句:
  }while(條件表達(dá)式)
  當(dāng)條件表達(dá)式為非零時(shí),繼續(xù)執(zhí)行循環(huán)體,直到條件表達(dá)式為零時(shí)退出循環(huán)。
  
  (10)設(shè)有如下程序:
  main()
  {int nl,n2;
  scanf("%df",&n2);
  while(n2!=0)
  { nl=n2%lO;
  n2=n2/10:
  printf("%d",n1);
  }
  }
  程序運(yùn)行后,如果從鍵盤(pán)上輸入1298,則輸出結(jié)果為  【10】   。
  答案:【10】8921
  評(píng)析:本題的程序的功能是將輸入的整數(shù)反向輸出。
  
  (11)以下程序輸出的最后一個(gè)值 【11】  。
  Int  ff(int n)
  {static int f=1:
  f=f*n:
  retun f
  }
  main()
  { int i;
  for(i=1;i<=5;i++)printf("%d\n",ff(i));
  }
  答案:【ll】120
  評(píng)析:
  靜態(tài)變量的類(lèi)型說(shuō)明符是static,靜態(tài)局部變量屬于靜態(tài)存儲(chǔ)方式,它具有以下特點(diǎn):
 、凫o態(tài)局部變量屬于靜態(tài)存儲(chǔ)類(lèi)別,在靜態(tài)存儲(chǔ)區(qū)內(nèi)分配存儲(chǔ)單元。在程序整個(gè)運(yùn)行期間都不釋放。
 、趯(duì)靜態(tài)局部變量是在編譯時(shí)賦初值的,即只賦初值一次,在程序運(yùn)行時(shí)它已有初值。以后每次調(diào)用函數(shù)時(shí)不再重新賦初值而只是保留上次函數(shù)調(diào)用結(jié)束時(shí)的值。
 、廴缭诙x局部變量時(shí)不賦初值的話,則對(duì)靜態(tài)局部變量來(lái)說(shuō),編譯時(shí)自動(dòng)賦初值0(對(duì)數(shù)值型變量)或空字符(對(duì)字符變量)。(注意:c語(yǔ)言中的非靜態(tài)變量在定義時(shí),系統(tǒng)并不會(huì)自動(dòng)給它賦初值)
 、茈m然靜態(tài)局部變量在函數(shù)調(diào)用結(jié)束后仍然存在,但其他函數(shù)是不能引用它的。
  本題中函數(shù)的功能是:與for語(yǔ)句一起求一個(gè)整數(shù)的階乘。
  
  (12)以下函數(shù)的功能是:求x的y次方,請(qǐng)?zhí)羁眨?BR>  double fun(double x,int y)
  {int i;
  double z;
  for(i=1,z=x;i<y;i++)z=z* 【12】  ;
  return z:
  )
  答案:【12】x
  評(píng)析:函數(shù)的定義形式為:
  函數(shù)類(lèi)型函數(shù)名(形參表)
  {
  類(lèi)型說(shuō)明語(yǔ)句;
  執(zhí)行語(yǔ)句:
  }
  本題中函數(shù)的功能是:累積變量以求得變量的Y次方。
  
  (13)下列程序的輸出結(jié)果是 【13】   。
  main()
  {
  int a[]={2,4,6},*ptr=&a[0],x=8,y,z;
  for(y=O;y<3;y++)
  z=(*(ptr+y)<x)?*(ptr十y):x;
  printf("%d\n",z);
  }
  答案:【13】6
  評(píng)析:條件運(yùn)算符的優(yōu)先級(jí)高于賦值運(yùn)算符,因此本題先計(jì)算關(guān)系表達(dá)式(*(ptr+y)<x)?*(ptr+y):x的值,再賦給變量z。當(dāng)y=O時(shí),*(ptr+y)=2,而x=8,(*ptr+y)<x)條件為真,則整個(gè)條件表達(dá)式的值為*(ptr+y)=2,所以Z=2;當(dāng)y=l時(shí),*(ptr+y)=4,(*(pty+y)<x)條件為真,則整個(gè)條件表達(dá)式的值為*(ptr+y)=4,所以z=4;當(dāng)y=2時(shí),*(ptr+y)=6,(*(ptr+y)<x)條件為真,則整個(gè)條件表達(dá)式的值為*(ptr+y)=6,所以z=6;循環(huán)結(jié)束。因此輸出z的結(jié)果為6。
  
  (14)以下程序運(yùn)行后的輸出結(jié)果是 【14】  。
  main()
  { char s[]="9876",*p;
  for(p=s;p<s+2;p++)printf("%s\n",p);
  }
  答案:【14】9876
  876
  評(píng)析:指針是一種數(shù)據(jù)類(lèi)型,這種數(shù)據(jù)類(lèi)型的變量用來(lái)存放內(nèi)存中分配的存儲(chǔ)單元的首地址。
  指針的定義:
  類(lèi)型說(shuō)明符 *指針變量名;
  
  (15)若有定義語(yǔ)句:char s[100],d[100];int j=0,i=0;且s中已賦字符串,請(qǐng)?zhí)羁找詫?shí)現(xiàn)拷貝。(注:不使用逗號(hào)表達(dá)式)
  while(s[i]){d[j]= 【15】    ;j++;}
  d[j]=0;
  答案:【15】s[i++]
  評(píng)析:本題中為了能實(shí)現(xiàn)字符串的拷貝,需要使字符數(shù)組s從頭到尾依次遍歷其所有元素。本題應(yīng)使用i的自增后置來(lái)實(shí)現(xiàn)。
  
  (16)若有如下結(jié)構(gòu)體說(shuō)明:
  struct STRU
  { int a,b;char c:double d:
  struct STRU *pl,*p2;
  };
  請(qǐng)?zhí)羁,以完成?duì)t數(shù)組的定義,t數(shù)組的每個(gè)元素為該結(jié)構(gòu)體類(lèi)型。
  【16】  t[20]
  答案:【16】struct STRU
  評(píng)析:結(jié)構(gòu)體類(lèi)型是構(gòu)造數(shù)據(jù)類(lèi)型,是用戶自己定義的一種類(lèi)型。
  結(jié)構(gòu)體類(lèi)型的定義:
  struct結(jié)構(gòu)體類(lèi)型名
  {
  成員項(xiàng)表:
  };
  定義結(jié)構(gòu)體變量的的形式為:
  struct結(jié)構(gòu)體類(lèi)型名 變量1,變量2,...
  其中變量包括:一般變量、指針變量、數(shù)組變量等。
  
  (17)下面的程序可對(duì)指定字符串中的字符串進(jìn)行從大到小排序,請(qǐng)將程序填完整(注:程序采用了冒泡排序算法)
  #include<stdio.h>
  #include<string.h>
  main()
  { char *str="ABCDabcd",temp;
  Int n,i;
  n=strlen(str);
  while(n-->1)
  for(i=0;i<n;i++)
  if(str[i]<str[i+1])
  { temp= 【17】 ;
  str[i]=str[i+1];
  _【18】  =temp;
  }
  Printf(_【19】  );
  }
  答案:【17】str[i]
  【18】str[i+1]
  【19】"%s",str
  評(píng)析:本題要求將字符串str中的字符用冒泡排序算法從大到小排列,其實(shí)現(xiàn)過(guò)程是將相鄰兩個(gè)字符進(jìn)行比較,如果當(dāng)前字符小于下一個(gè)字符,則通過(guò)中間變量temp將字符兩兩交換,所以第一空應(yīng)填:str[i],第二空應(yīng)填:str[i+1]。最終打印輸出得到的字符串str,所以第三空應(yīng)填;"%s",str。
  
  (18)以下程序段打開(kāi)文件后,先利用fseek函數(shù)將文件位置指針定位在文件末尾,然后調(diào)  用ftell函數(shù)返回當(dāng)前文件位置指針的具體位置,從而確定文件長(zhǎng)度,請(qǐng)?zhí)羁铡?BR>  FILE *myf;long fl;
  myf=_【20】  ("test.t","rb");
  fseek(myf,(),SEEK_END);fl+ftell(myf);
  fclose(myf);
  printf("%l d\n",f1);
  答案:【20】fopen
  評(píng)析:C語(yǔ)言中的文件分為:ASCII文件與二進(jìn)制文件。文件在使用前打開(kāi),使用后要關(guān)閉。
  打開(kāi)文件的函數(shù)為:fopen(),調(diào)用形式為:fp=fopen("文件名","使用文件方式");
  關(guān)閉文件的函數(shù)為:fclose(),調(diào)用形式為:fclose(fp);其中fp為文件指針。

上一頁(yè)  [1] [2] 

文章錄入:ak47    責(zé)任編輯:ak47  
 版權(quán)聲明
   如果本網(wǎng)站所轉(zhuǎn)載內(nèi)容不慎侵犯了您的權(quán)益,請(qǐng)與我們聯(lián)系,我們將會(huì)及時(shí)處理。如轉(zhuǎn)載本網(wǎng)內(nèi)容,請(qǐng)注明出處。
 發(fā)表評(píng)論
關(guān)于本站 網(wǎng)站聲明 廣告服務(wù)  聯(lián)系方式  付款方式  站內(nèi)導(dǎo)航  客服中心  友情鏈接   
Copyright © 2004-2006 考試吧 (Exam8.com) All Rights Reserved 
中國(guó)科學(xué)院研究生院中關(guān)村園區(qū)(北京市海淀區(qū))