版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
2022年3月全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案(1)下列敘述中正確的是
A)棧是先進(jìn)先出(FIFO)的線性表B)隊(duì)列是先進(jìn)先出(FIFO)的線性表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)簡(jiǎn)單選擇排序
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)試通常也稱為DebugD)軟件測(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如下:RSABCa32b01c21ABa3b0c2
由關(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ù)中有定義語句:intk;,則
A)系統(tǒng)將自動(dòng)給k賦初值0
B)這時(shí)k中值無定義
C)系統(tǒng)將自動(dòng)給k賦初值-1
D)這時(shí)k中無任何值(13)以下選項(xiàng)中,能用作數(shù)據(jù)常量的是
A)o115
B)0118
C)1.5e1.5
D)115L(14)設(shè)有定義:intx=2;,以下表達(dá)式中,值不為6的是A)x*=x+1
B)x++,2*x
C)x*=(1+x)
D)2*x,x+=2(15)程序段:intx=12;
doubley=3.141593;printf(“%d%8.6f”,x,y);的輸出結(jié)果是A)123.141593
B)12
3.141593
C)12,3.141593
D)123.141593(16)若有定義語句:doublex,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<stdio.h>main(){intx;scanf(“%d”,&x);if(x<=3);elseif(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<stdio.h>Main(){
inta=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);elseprintf(“%d,%d,%d\n”,a,b,c);elseprintf(“%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<stdio.h>main(){char
*s=(“ABC);do{printf(“%d”,*s%10);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<stdio.h>main(){inta1,a2;charc1,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,則正確的輸入格式是(以下
代表空格,<CR>代表回車)A)12a34b<CR>
B)12
a
34
b<CR>C)12,a,34,b<CR>
D)12
a34
b<CR>(24)有以下程序#include<stdio.h>intf(intx,inty){return()y-x)*x);}main(){inta=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<stdio.h>voidfun(char
*s){while(*s)
{if(*s%2==0)
printf(“%c”,*s);s++;
}}main(){char
a[]={“good”};
fun(a);printf(“\n”);}注意:字母a的ASCII碼值為97,程序運(yùn)行后的輸出結(jié)果是A)d
B)go
C)god
D)good(26)有以下程序#include<stdio.h>voidfun(int*a,int*b){int*c;c=a;a=b;b=c;}main(){intx=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<stdio.h>voidf(int*p,int*q);main(){intm=1,n=2,*r=&m;
f(r,&n);printf(“%d,%d”,m,n);}voidf(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ù)voidfun(int*w,intn){inti;
for(i=0;i<n;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)若有以下定義
intx[10],*pt=x;則對(duì)x數(shù)組元素的正確應(yīng)用是A)*&x[10]
B)*(x+3)
C)*(pt+10)
D)pt+3
(30)設(shè)有定義:chars[81];inti=10;,以下不能將一行(不超過80個(gè)字符)帶有空格的字符串真確讀入的語句或語句組是Agets(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<stdio.h>main(){char*a[]={“abcd”,”ef”,”gh”,”ijk”};intI;
for(i=0;i<4;i++)
printf(“%c”,*a);}程序運(yùn)行后輸出的結(jié)果是A)aegi
B)dfhk
C)abcd
D)abcdefghijk(32)以下選項(xiàng)中正確的語句組是A)chars[];s=”BOOK!”;
B)char*s;s={”BOOK!”};C)chars[10];s=”BOOK!”;
D)char*s;s=”BOOK!”;(33)有以下程序#include<stdio.h>intfun{intx,inty}{if(x==y)return(x);
elsereturn((x+y)/2)}main(){inta=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<stdio.h>intb=2;intfun(int*k){b=*k+b;return(b);}main(){inta[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
12
B)8
10
C)10
28
D)10
16(36)有以下程序#include<stdio.h>#definePT3.5;#defineS(x)PT*x*x;main(){inta=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<stdio.h>structord{intx,y;}dt[2]={1,2,3,4};main(){structord*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整除是否余1D)判斷m被5和7整除是否余1(39)有以下程序#include<stdio.h>main(){inta=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<stdio.h>main(){FILE*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分)
請(qǐng)將每一個(gè)空的正確答案寫在答題卡【1】至【15】序號(hào)的橫線上,答在試卷上不得分。(1)假設(shè)一個(gè)長(zhǎng)度為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<stdio.h>main(){
charc1,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<stdio.h>main(){intk=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<stdio.h>main(){char
a=0,ch;while((ch=getchar())!=’\n’){if(a&2!=0&&(ch>’a’&&ch<=’z’))ch=ch-‘a(chǎn)’+’A’;a++;putchar(ch);}printf(“\n”);}(11)有以下程序,程序執(zhí)行后,輸出結(jié)果是【11】#include<stdio.h>voidfun(int*a){a[0=a[1];]}main(){inta[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<stdio.h>int【12】;main(){intx,y,(*p)();p=max;printf(“&d\n”,&x,&y);}Intmax(inta,intb){return(a>b/a:b);}(13)以下程序用來判斷指定文件是否能正常打開,請(qǐng)?zhí)羁?include<stdio.h>main(){FILE*fp;if(((fp=fopen(“test.txt”,”r”))==【13】))printf(“未能打開文件!\n”);elseprintf(“文件打開成功!\n”);(14)下列程序的運(yùn)行結(jié)果為【14】#include<stdio.h>#include<string.h>structA{inta;charb[10];double
c;};void
f(struct
A
*t);main(){structAa=(1001,”ZhangDa”,1098,0);f(&a);printf(“&d,&s,&6,if\n”,a.a,a.b,a.c);}voidf(struct
A
*t){strcpy(t->b,”ChangRong”);
}(15)以下程序把三個(gè)NODETYPE型的變量鏈接成一個(gè)簡(jiǎn)單的鏈表,并在while循環(huán)中輸出鏈表結(jié)點(diǎn)數(shù)據(jù)域中的數(shù)據(jù),請(qǐng)?zhí)羁?include<stdio.h>structnode{intdata;structnode*next;};typedefstructnodeNODETYPE;main(){NODETYPEa,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~10DACDCABABC11~20CBDDACDBCD21~30CDABABACBC31~40ADBCCDBDAC二、選擇題1.192.白盒3.順序結(jié)構(gòu)4.數(shù)據(jù)庫管理系統(tǒng)5.菱形6.47.“x/y=%d”8.不能9.s=010.1AbCeDf2Df11.777765432112.max(inta,intb)13.NULL14.1001ChangRong1008.015.p++或p=p->next2022年9月全國計(jì)算機(jī)等級(jí)考試二級(jí)C語言筆試試題及答案一、選擇題((1)—(10)、(21)—(40)每題2分,(11)—(20)每題1分,共70分)(1)下列數(shù)據(jù)結(jié)構(gòu)中,屬于非線性結(jié)構(gòu)的是A)循環(huán)隊(duì)列B)帶鏈隊(duì)列C)二叉樹D)帶鏈棧(2)下列數(shù)據(jù)結(jié)果中,能夠按照“先進(jìn)后出”原則存取數(shù)據(jù)的是A)循環(huán)隊(duì)列B)棧C)隊(duì)列D)二叉樹(3)對(duì)于循環(huán)隊(duì)列,下列敘述中正確的是A)隊(duì)頭指針是固定不變的B)隊(duì)頭指針一定大于隊(duì)尾指針C)隊(duì)頭指針一定小于隊(duì)尾指針D)隊(duì)頭指針可以大于隊(duì)尾指針,也可以小于隊(duì)尾指針(4)算法的空間復(fù)雜度是指A)算法在執(zhí)行過程中所需要的計(jì)算機(jī)存儲(chǔ)空間B)算法所處理的數(shù)據(jù)量C)算法程序中的語句或指令條數(shù)D)算法在執(zhí)行過程中所需要的臨時(shí)工作單元數(shù)(5)軟件設(shè)計(jì)中劃分模塊的一個(gè)準(zhǔn)則是A)低內(nèi)聚低耦合B)高內(nèi)聚低耦合C)低內(nèi)聚高耦合D)高內(nèi)聚高耦合(6)下列選項(xiàng)中不屬于結(jié)構(gòu)化程序設(shè)計(jì)原則的是A)可封裝D)自頂向下C)模塊化D)逐步求精(7)軟件詳細(xì)設(shè)計(jì)產(chǎn)生的圖如下:該圖是A)N-S圖B)PAD圖C)程序流程圖D)E-R圖(8)數(shù)據(jù)庫管理系統(tǒng)是A)操作系統(tǒng)的一部分B)在操作系統(tǒng)支持下的系統(tǒng)軟件C)一種編譯系統(tǒng)D)一種操作系統(tǒng)(9)在E-R圖中,用來表示實(shí)體聯(lián)系的圖形是A)橢圓圖B)矩形C)菱形D)三角形(10)有三個(gè)關(guān)系R,S和T如下:
其中關(guān)系T由關(guān)系R和S通過某種操作得到,該操作為A)
選擇B)
投影C)
交D)
并(11)以下敘述中正確的是A)程序設(shè)計(jì)的任務(wù)就是編寫程序代碼并上機(jī)調(diào)試B)程序設(shè)計(jì)的任務(wù)就是確定所用數(shù)據(jù)結(jié)構(gòu)C)程序設(shè)計(jì)的任務(wù)就是確定所用算法D)以上三種說法都不完整(12)以下選項(xiàng)中,能用作用戶標(biāo)識(shí)符的是A)voidB)8_8C)_0_D)unsigned(13)閱讀以下程序#include<stdio.h>main(){intcase;floatprintF;printf(“請(qǐng)輸入2個(gè)數(shù):”);scanf(“%d%f”,&case,&pjrintF);printf(“%d%f\n”,case,printF);}該程序編譯時(shí)產(chǎn)生錯(cuò)誤,其出錯(cuò)原因是A)定義語句出錯(cuò),case是關(guān)鍵字,不能用作用戶自定義標(biāo)識(shí)符B)定義語句出錯(cuò),printF不能用作用戶自定義標(biāo)識(shí)符C)定義語句無錯(cuò),scanf不能作為輸入函數(shù)使用D)定義語句無錯(cuò),printf不能輸出case的值(14)表達(dá)式:(int)((double)9/2)-(9)%2的值是A)0B)3C)4D)5(15)若有定義語句:intx=10;,則表達(dá)式x-=x+x的值為A)-20B)-10C)0D)10(16)有以下程序#include<stdio.h>main(){inta=1,b=0;printf(“%d,”,b=a+b);printf(“%d\n”,a=2*b);}程序運(yùn)行后的輸出結(jié)果是A)0,0B)1,0C)3,2D)1,2(17)設(shè)有定義:inta=1,b=2,c=3;,以下語句中執(zhí)行效果與其它三個(gè)不同的是A)if(a>b)c=a,a=b,b=c;B)if(a>b){c=a,a=b,b=c;}C)if(a>b)c=a;a=b;b=c;D)if(a>b){c=a;a=b;b=c;}(18)有以下程序#include<stdio.h>main(){intc=0,k;for(k=1;k<3;k++)switch(k){default:c+=kcase2:c++;break;case4:c+=2;break;}printf(“%d\n”,c);}程序運(yùn)行后的輸出結(jié)果是A)3B)5C)7D)9(19)以下程序段中,與語句:k=a>b?(b>c?1:0):0;功能相同的是A)if((a>b)&&(b>c))k=1;elsek=0;B)if((a>b)||(b>c)k=1;elsek=0;C)if(a<=b)k=0;elseif(b<=c)k=1;D)if(a>b)k=1;elseif(b>c)k=1;elsek=0;(20)有以下程序#include<stdio.h>main(){chars[]={“012xy”};inti,n=0;for(i=0;s[i]!=0;i++)if(s[i]>=’a’&&s[i]<=’z’)n++;printf(“%d\n”,n);}程序運(yùn)行后的輸出結(jié)果是A)0B)2C)3D)5(21)有以下程序#include<stdio.h>main(){intn=2,k=0;while(k++&&n++>2);printf(“%d%d\n”,k,n);}程序運(yùn)行后的輸出結(jié)果是A)02B)13C)57D)12(22)有以下定義語句,編譯時(shí)會(huì)出現(xiàn)編譯錯(cuò)誤的是A)chara=’a’;B)chara=’\n’;C)chara=’aa’;D)chara=’\x2d’;(23)有以下程序#include<stdio.h>main(){charc1,c2;c1=’A’+’8’-‘4’;c2=’A’+’8’-‘5’;printf(“%c,%d\n”,c1,c2);}已知字母A的ASCII碼為65,程序運(yùn)行后的輸出結(jié)果是A)E,68B)D,69C)E,DD)輸出無定值(24)有以下程序#include<stdio.h>voidfun(intp){intd=2;p=d++;printf(“%d”,p);}main(){inta=1;fun(a);printf(“%d\n”,a);}程序運(yùn)行后的輸出結(jié)果是A)32B)12C)21D)22(25)以下函數(shù)findmax擬實(shí)現(xiàn)在數(shù)組中查找最大值并作為函數(shù)值返回,但程序中有錯(cuò)導(dǎo)致不能實(shí)現(xiàn)預(yù)定功能#defineMIN-2147483647intfindmax(intx[],intn){inti,max;for(i=0;i<n;i++){max=MIN;if(max<x[i])max=x[i];}returnmax;}造成錯(cuò)誤的原因是A)定義語句inti,max;中max未賦初值B)賦值語句max=MIN;中,不應(yīng)給max賦MIN值C)語句if(max<x[i])max=x[i];中判斷條件設(shè)置錯(cuò)誤D)賦值語句max=MIN;放錯(cuò)了位置(26)有以下程序#include<stdio.h>main(){intm=1,n=2,*p=&m,*q=&n,*r;r=p;p=q;q=r;printf(“%d,%d,%d,%d\n”,m,n,*p,*q);}程序運(yùn)行后的輸出結(jié)果是A)1,2,1,2B)1,2,2,1C)2,1,2,1D)2,1,1,2(27)若有定義語句:inta[4][10],*p,*q[4];且0≤i<4,則錯(cuò)誤的賦值是A)p=aB)q[i]=a[i]C)p=a[i]D)p=&a[2][1](28)有以下程序#include<stdio.h>#include<string.h>main(){charstr[][20]={“One*World”,“One*Dream!”},*p=str[1];printf(“%d,”,strlen(p));printf(“%s\n”,p);}程序運(yùn)行后的輸出結(jié)果是A)9,One*WorldB)9,One*DreamC)10,One*DreamD)10,One*World(29)有以下程序#include<stdio.h>main(){inta[]={2,3,5,4},i;for(i=0;i<4;i++)switch(i%2){case0:switch(a[i]%2){case0:a[i]++;break;case1:a[i]--;}break;case1:a[i[=0;}for(i=0;i<4;i++)printf(“%d”,a[i]);printf(“\n”);}A)3344B)2050C)3040D)0304(30)有以下程序#include<stdio.h>#include<string.h>main(){chara[10]=”abcd”;printf(“%d,%d\n”,strlen(a),sizeof(a));}程序運(yùn)行后的輸出結(jié)果是A)7,4B)4,10C)8,8D)10,10(31)下面是有關(guān)C語言字符數(shù)組的描述,其中錯(cuò)誤的是A)不可以用賦值語句給字符數(shù)組名賦字符串B)可以用輸入語句把字符串整體輸入給字符數(shù)組C)字符數(shù)組中的內(nèi)容不一定是字符串D)字符數(shù)組只能存放字符串(32)下列函數(shù)的功能是fun(char*a,char*b){while((*b=*a)!=’\0’){a++,b++;}}A)將a所指字符串賦給b所指空間B)使指針b指向a所指字符串C)將a所指字符串和b所指字符串進(jìn)行比較D)檢查a和b所指字符串中是否有’\0’
(33)設(shè)有以下函數(shù)voidfun(intn,char*s){……}則下面對(duì)函數(shù)指針的定義和賦值均是正確的是A)void(*pf)();pf=fun;B)viod*pf();pf=fun;C)void*pf();*pf=fun;D)void(*pf)(int,char);pf=&fun;(34)有以下程序#include<stdio.h>intf(intn);main(){inta=3,s;s=f(a);s=s+f(a);printf(“%d\n”,s);}intf(intn){staticinta=1;n+=a++;returnn;}程序運(yùn)行以后的輸出結(jié)果是A)7B)8C)9D)10(35)有以下程序#include<stdio.h>#definef(x)x*x*xmain(){inta=3,s,t;s=f(a+1);t=f((a+1));printf(“%d,%d\n’,s,t);}程序運(yùn)行后的輸出結(jié)果是A)10,64B)10,10C)64,10D)64,64(36)下面結(jié)構(gòu)體的定義語句中,錯(cuò)誤的是A)structord{intx;inty;intz;};structorda;B)structord{intx;inty;intz;}structorda;C)structord{intx;inty;intz;}a;D)struct{intx;inty;intz;}a;(37)設(shè)有定義:char*c;,以下選項(xiàng)中能夠使字符型指針c正確指向一個(gè)字符串的是A)charstr[]=”string”;c=str;B)scanf(“%s”,c);C)c=getchar();D)*c=”string”;(38)有以下程序#include<stdio.h>
#include<string.h>structA{inta;charb[10];doublec;};structAf(structAt);main(){structAa={1001,”ZhangDa”,1098.0};a=f(a);jprintf(“%d,%s,%6.1f\n”,a.a,a.b,a.c);}structAf(structAt)(t.a=1002;strcpy(t.b,”ChangRong”);t.c=1202.0;returnt;)程序運(yùn)行后的輸出結(jié)果是A)1001,ZhangDa,1098.0B)1001,ZhangDa,1202.0C)1001,ChangRong,1098.0D)1001,ChangRong,1202.0(39)若有以下程序段intr=8;printf(“%d\n”,r>>1);輸出結(jié)果是A)16B)8C)4D)2(40)下列關(guān)于C語言文件的敘述中正確的是A)文件由一系列數(shù)據(jù)依次排列組成,只能構(gòu)成二進(jìn)制文件B)文件由結(jié)構(gòu)序列組成,可以構(gòu)成二進(jìn)制文件或文本文件C)文件由數(shù)據(jù)序列組成,可以構(gòu)成二進(jìn)制文件或文本文件D)文件由字符序列組成,其類型只能是文本文件二、填空題(每空2分,共30分)(1)某二叉樹有5個(gè)度為2的結(jié)點(diǎn)以及3個(gè)度為1的結(jié)點(diǎn),則該二叉樹中共有【1】個(gè)結(jié)點(diǎn)。(2)程序流程圖中的菱形框表示的是【2】。(3)軟件開發(fā)過程主要分為需求分析、設(shè)計(jì)、編碼與測(cè)試四個(gè)階段,其中【3】階段產(chǎn)生“軟件需求規(guī)格說明書。(4)在數(shù)據(jù)庫技術(shù)中,實(shí)體集之間的聯(lián)系可以是一對(duì)一或一對(duì)多或多對(duì)多的,那么“學(xué)生”和“可選課程”的聯(lián)系為【4】。(5)人員基本信息一般包括:身份證號(hào),姓名,性別,年齡等。其中可以作為主關(guān)鍵字的是【5】。(6)若有定義語句:inta=5;,則表達(dá)式:a++的值是【6】。(7)若有語句doublex=17;inty;,當(dāng)執(zhí)行y=(int)(x/5)%2;之后y的值為【7】。(8)以下程序運(yùn)行后的輸出結(jié)果是【8】。#include<stdio.h>main(){intx=20;printf(“%d”,0<x<20);printf(“%d\n”,0<x&&x<20);}(9)以下程序運(yùn)行后的輸出結(jié)果是【9】。#include<stdio.h>main(){inta=1,b=7;do{b=b/2;a+=b;}while(b>1);printf(“%d\n”,a);}(10)有以下程序#include<stdio.h>main(){intf,f1,f2,i;f1=0;f2=1;printf(“%d%d”,f1,f2);for(i=3;i<=5;i++){f=f1+f2;printf(“%d”,f);f1=f2;f2=f;}printf(“\n”);}程序運(yùn)行后的輸出結(jié)果是【10】。(11)有以下程序#include<stdio.h>inta=5;voidfun(intb){inta=10;a+=b;printf(“%d”,a);}main(){intc=20;fun(c);a+=c;printf(“%d\n”,a);}程序運(yùn)行后的輸出結(jié)果是【11】。(12)設(shè)有定義:structperson{intID;charname[12];}p;請(qǐng)將scanf(“%d”,【12】);語句補(bǔ)充完整,使其能夠?yàn)榻Y(jié)構(gòu)體變量p的成員ID正確讀入數(shù)據(jù)。(13)有以下程序#include<stdio.h>main(){chara[20]=”Howareyou?”,b[20];scanf(“%s”,b);printf(“%s%s\n”,a,b);}程序運(yùn)行時(shí)從鍵盤輸入:Howareyou?<回車>則輸出結(jié)果為【13】。(14)有以下程序#include<stdio.h>typedefstruct{intnum;doubles}REC;voidfun1(RECx){x.num=23;x.s=88.5;}main(){RECa={16,90.0};fun1(a);printf(“%d\n”,a.num);}程序運(yùn)行后的輸出結(jié)果是【14】。(15)有以下程序#include<stdio.h>fun(intx){if(x/2>0)run(x/2);printf(“%d”,x);}main(){fun(6);printf(“\n”);}程序運(yùn)行后的輸出結(jié)果是【15】。一、選擇題1~10CBDABACBCD11~20DCABBDCAAB21~30DCACDBACCB31~40DAACABADCC二、選擇題1.142.邏輯條件3.需求分析4.多對(duì)多5.身份證號(hào)6.57.18.109.510.0112311.302512.&p.ID13.Howareyou?How14.1615.1362010年3月全國計(jì)算機(jī)等級(jí)考試二級(jí)筆試試卷C語言程序設(shè)計(jì)及參考答案(考試時(shí)間90分鐘,滿分100分)一、選擇題((1)—(10)、(21)—(40)每題2分,(11)—(20)每題1分。共70分)下列各題A)、B)、C)、D)四個(gè)選項(xiàng)中,只有一個(gè)選項(xiàng)是正確的,請(qǐng)將正確選項(xiàng)涂寫在答題卡上,答在試卷上不得分。(1)下列敘述中正確的是A)對(duì)長(zhǎng)度為n的有序鏈表進(jìn)行查找,最壞情況下需要的比較次數(shù)為nB)對(duì)長(zhǎng)度為n的有序鏈表進(jìn)行對(duì)分查找,最壞情況下需要的比較次數(shù)為(n/2)C)對(duì)長(zhǎng)度為n的有序鏈表進(jìn)行對(duì)分查找,最壞情況下需要的比較次數(shù)為(log2n)D)對(duì)長(zhǎng)度為n的有序鏈表進(jìn)行對(duì)分查找,最壞情況下需要的比較次數(shù)為(nlog2n)(2)算法的時(shí)間復(fù)雜度是指
A)算法的執(zhí)行時(shí)間
B)算法所處理的數(shù)據(jù)量
C)算法程序中的語句或指令條數(shù)
D)算法在執(zhí)行過程中所需要的基本運(yùn)算次數(shù)(3)軟件按功能可以分為:應(yīng)用軟件、系統(tǒng)軟件和支撐軟件(或工具軟件)。下面屬于系統(tǒng)軟件的是
A)編輯軟件
B)操作系統(tǒng)
C)教務(wù)管理系統(tǒng)
D)瀏覽器(4)軟件(程序)調(diào)試的任務(wù)是
A)診斷和改正程序中的錯(cuò)誤
B)盡可能多地發(fā)現(xiàn)程序中的錯(cuò)誤
C)發(fā)現(xiàn)并改正程序中的所有錯(cuò)誤
D)確定程序中錯(cuò)誤的性質(zhì)(5)數(shù)據(jù)流程圖(DFD圖)是
A)軟件概要設(shè)計(jì)的工具
B)軟件詳細(xì)設(shè)計(jì)的工具
C)結(jié)構(gòu)化方法的需求分析工具
D)面向?qū)ο蠓椒ǖ男枨蠓治龉ぞ?6)軟件生命周期可分為定義階段,開發(fā)階段和維護(hù)階段。詳細(xì)設(shè)計(jì)屬于
A)定義階段
B)開發(fā)階段
C)維護(hù)階段
D)上述三個(gè)階段(7)數(shù)據(jù)庫管理系統(tǒng)中負(fù)責(zé)數(shù)據(jù)模式定義的語言是
A)數(shù)據(jù)定義語言
B)數(shù)據(jù)管理語言
C)數(shù)據(jù)操縱語言
D)數(shù)據(jù)控制語言(8)在學(xué)生管理的關(guān)系數(shù)據(jù)庫中,存取一個(gè)學(xué)生信息的數(shù)據(jù)單位是
A)文件
B)數(shù)據(jù)庫
C)字段
D)記錄(9)數(shù)據(jù)庫設(shè)計(jì)中,用E-R圖來描述信息結(jié)構(gòu)但不涉及信息在計(jì)算機(jī)中的表示,它屬于數(shù)據(jù)庫設(shè)計(jì)的
A)需求分析階段
B)邏輯設(shè)計(jì)階段C)概念設(shè)計(jì)階段D)物理設(shè)計(jì)階段
(10)有兩個(gè)關(guān)系R和T如下:R
TABCa12b22c32ABCc32d32則由關(guān)系R得到關(guān)系T的操作是A)選擇
B)投影
C)交
D)并(11)以下敘述正確的是A)C語言程序是由過程和函數(shù)組成的B)C語言函數(shù)可以嵌套調(diào)用,例如:fun(fun(x))C)C語言函數(shù)不可以單獨(dú)編譯D)C語言中除了main函數(shù),其他函數(shù)不可以作為單獨(dú)文件形式存在(12)以下關(guān)于C語言的敘述中正確的是A)C語言中的注釋不可以夾在變量名或關(guān)鍵字的中間B)C語言中的變量可以再使用之前的任何位置進(jìn)行定義C)在C語言算術(shù)的書寫中,運(yùn)算符兩側(cè)的運(yùn)算數(shù)類型必須一致D)C語言的數(shù)值常量中夾帶空格不影響常量值的正確表示(13)以下C語言用戶標(biāo)示符中,不合法的是A)_1
B)AaBc
C)a_b
D)a--b(14)若有定義:doublea=22;inti=0,k=18;則不符合C語言規(guī)定的賦值語句是A)a=a++,i++
B)i=(a+k)<=(i+k)
C)i=a%11
D)i=!a(15)#include<stdio.h>main(){chara,b,c,d;scanf("%c%c",&a,&b);c=getchar();
d=getchar();printf("%c%c%c%c\n",a,b,c,d);}當(dāng)執(zhí)行程序時(shí),按下列方式輸入數(shù)據(jù)(從第一列開始,<CR>代表回車,注意:回車是一個(gè)字符)12<CR>34<CR>則輸出結(jié)果是:A)1234
B)12
C)12
D)12
3
34(16)以下關(guān)于C語言數(shù)據(jù)類型使用的敘述中錯(cuò)誤的是:A)若要準(zhǔn)確無誤的表示自然數(shù),應(yīng)使用整數(shù)類型。B)若要保存帶有多位小數(shù)的數(shù)據(jù),應(yīng)使用雙精度類型。C)若要處理如"人員信息"等含有不同類型的相關(guān)數(shù)據(jù),應(yīng)自定義結(jié)構(gòu)體類型。D)若只處理"真"和"假"兩種邏輯值,應(yīng)使用邏輯類型。(17)若a是數(shù)值類型,則邏輯表達(dá)式(a==1)||(a!=1)的值是:A)1
B)0
C)2
D)不知道a的值,不能確定(18)以下選項(xiàng)中與if(a==1)a=b;elsea++;語句功能不同的switch語句是:A)switch(a)
B)switch(a==1)
{case1:a=b;break;
{
case0:a=b;break;
default:a++;
case1:a++;}
}C)switch(a)
D)switch(a==1)
{
default:a++;break;
{
case1:a=b;break;
case1:a=b;
case0:a++;}
}(19)有如下嵌套的if語句
if(a<b)
if(a<c)
k=a;
else
k=c;
else
if(b<c)
k=b;
else
k=c;以下選項(xiàng)中與上述if語句等價(jià)的語句是A)k=(a<b)?a:b;k=(b<c)?b:c;B)k=(a<b)?((b<c)?a:b):((b<c)?b:c);C)k=(a<b)?((a<c)?a:c):((b<c)?b:c);D)k=(a<b)?a:b;k=(a<c)?a;c(20)有以下程序#include
<stdio.h>main(){inti,j,m=1;for(i=1;i<3;i++){for(j=3;j>0;j--){if(i*j>3)break;m*=i*j;}}printf("m=%d\n",m)}程序運(yùn)行后的輸出結(jié)果是A)m=6
B)m=2
C)m=4
D)m=5
(21)有以下程序#includes<stdio.h>main(){inta=1,b=2;
for(;a<8;a++){b+=a;a+=2;}printf("%d,%d\n",a,b);}程序運(yùn)行后的輸出結(jié)果是A)9,18
B)8,11
C)7,11
D)10,14(22)有以下程序,其中k的初值為八進(jìn)制數(shù)#include<stdio.h>main(){intk=011;printf("%d\n",k++);}程序運(yùn)行后的輸出結(jié)果是A)12
B)11
C)10
D)9(23)下列語句中,正確的是A)char*s;s="Olympic";
B)chars[7];s="Olympic";C)char*s;s={"Olympic"};
D)chars[7];s={"Olympic"};(24)以下關(guān)于return語句的敘述中正確的是A)一個(gè)自定義函數(shù)中必須有一條return語句B)一個(gè)自定義函數(shù)中可以根據(jù)不同情況設(shè)置多條return語句C)定義成viod類型的函數(shù)中可以有帶返回值的return語句D)沒有return語句的自定義函數(shù)在執(zhí)行結(jié)束時(shí)不能返回到調(diào)用處
(25)下列選項(xiàng)中,能夠正確定義數(shù)組的語句是A)intnum[0..2008];
B)intnum[];C)intN=2008;
D)#defineN2008
intnum[N];
intnum[N](26)有以下程序#include<stdio.h>voidfun(char*c,intd){*c=*c+1;d=d+1;printf("%c,%c,",*c,d);}main(){charb=’a’,a=’A’;
fun(&b,a);printf("%c,%c\n",b,a);}程序運(yùn)行后的輸出結(jié)果是
A)b,B,b,A
B)b,B,B,A
C)a,B,B,a
D)a,B,a,B
(27)若有定義int(*pt)[3];,則下列說法正確的是A)定義了基類型為int的三個(gè)指針變量B)定義了基類型為int的具有三個(gè)元素的指針數(shù)組pt。C)定義了一個(gè)名為*pt、具有三個(gè)元素的整型數(shù)組D)定義了一個(gè)名為pt的指針變量,它可以指向每行有三個(gè)整數(shù)元素的二維數(shù)組
(28)設(shè)有定義doublea[10],*s=a;,一下能夠代表數(shù)組元素a[3]的是A)(*s)[3]
B)*(s+3)
C)*s[3]
D)*s+3
(29)有以下程序#include<stdio.h>main(){inta[5]={1,2,3,4,5},b[5]={0,2,1,3,0},is=0
for(i=0;i<5;i++)s=s+a[b[i]];printf("%d\n",s);}程序運(yùn)行后的輸出結(jié)果是A)6
B)10
C)11
D)1530)有以下程序
#include<stdio.h>
main(){intb[3][3]={0,1,2,0,1,2,0,1,2},i,j,t=1;
for(i=0;i<3;i++)For(j=i;j<=i;j++)
t+=b[i][b[j][i]];Printf("%d\n",t);}程序運(yùn)行后的輸出結(jié)果是A)1
B)3
C)4
D)9(31)若有以下定義和語句charsl[10]="abcd!",*s2="n123\\";
printf("%d%d\n",strlen(s1),strlen(s2));則輸出結(jié)果是A)55
B)105
C)107
D)58(32)有以下程序
#include<stdio.h>
#defineN8
voidfun(int
*x,inti)
{*x=*(x+i);}main(){inta[N]={1,2,3,4,5,6,7,8},i;fun(a,2);for(i=0;i<N/2);i++){printf("%d",a[i]);}printf("\n");}程序運(yùn)行后的輸出結(jié)果是A)1313
B)2234
C)3234
D)1234(33)有以下程序#include<studio.h>intf(intt[],intn);main(){inta[4]={1,2,3,4},s;s=f{a,4};printf("%d\n",s);}intf(intt[],intn){if(n>0)
returnt[n-1]+f(t,n-1);else
return0;}程序運(yùn)行后的輸出結(jié)果是A)4
B)10
C)14
D)6
(34)有以下程序#include<studio.h>intfun(){staticint
x=1;x*=2;return
x;}main(){intI,s=1;for(i=1;i<=2;i++)
s=fun();printf("%d\n",s);}程序運(yùn)行后的輸出結(jié)果是A)0
B)1
C)4
D)8(35)以下程序#include<stdio.h>#define
SUB(a)
(a)-(a)main(){int
a=2,b=3,c=5,d;d=SUB(a+b)*c;printf("%d\n",d);}程序運(yùn)行后的結(jié)果是A)0
B)-12
C)-20
D)10(36)沒有定義structcomplex{
int
real,unreal;}datal={1,8},data2;則以下賦值語句中的錯(cuò)誤的是A)data2=data1;
B)data2=(2,6);C)data2.real1=data1.real;
D)data2.real=data1.unreal;
(37)有以下程序#include<studio.h>#include<string.h>structA{inta;charb[10];doublec;};voidf(struct
A
t);main(){struct
A
a={1001,"ZhangDa",1098.0};f(a);pringt("%d,%s,%6.1f\n",a.a,a.b,a.c);}voidf(struct
A
t){t.a=1002;strcpy(t.b,"ChangRong");t.c=1202.0;}程序運(yùn)行后的輸出結(jié)果是A)1001,ZhangDa,1098.0
B)1002,ChangRong,1202.0C)1001,ChangRong,1098.0
D)1002,ZhangDa,1202.0(38)有以下定義和語句struct
workers{int
num;charname[20];charc;srruct{intday;intmonth;intyear;}s;};structworkers
w,*pw;pw=&w能給w中year成員賦1980的語句是A)*pw.year=1980;
B)w.year=1980;C)pw->year=1980;
D)w.s.year=1980;(39)有以下程序#include<stdio.h>main(){inta=2,b=2,c=2;printf("%d\n",a/b&c);}程序運(yùn)行后的結(jié)果是A)0
B)1
C)2
D)3(40)以下程序#include<stdio.h>main(){
FILE
*fp;char
str[10];fp=fopen("myfile.dat","w");fputs("abc",fp);
fclose(fp);fp=fopen("myfile.dat","a+");rewind(fp,"gd",28);rewind(fp);fscanf(fp,"gs",str);
puts(str);fclose(fp);}程序運(yùn)行后的輸出結(jié)果是A)abc
B)28c
C)abc28
D)因類型不一致而出錯(cuò)二、填空題(每空2分,共30分)請(qǐng)將每空的正確答案寫在答題卡【1】至【15】序號(hào)的橫線上,答在試卷上不得分。(1)一個(gè)隊(duì)列的初始狀態(tài)為空,先將元素A,CB,C,D,E,F,5,4,3,2,1依次入隊(duì),然后再依次退隊(duì),則元素退隊(duì)的順序?yàn)開__【1】__。(2)設(shè)某循環(huán)列隊(duì)的容量為50,如果頭指針front=45(指向隊(duì)頭元素的前一位置),尾指針rear=10(指向隊(duì)尾元素),則該循環(huán)隊(duì)列中共有___【2】__個(gè)元素。(3)設(shè)二叉數(shù)如下:對(duì)該二叉樹進(jìn)行后序遍歷的結(jié)果為【3】(4)軟件是
【4】
、數(shù)據(jù)和文檔的集合。(5)有一個(gè)學(xué)生選課的關(guān)系,其中學(xué)生的關(guān)系模式為:學(xué)生(學(xué)號(hào),姓名,班級(jí),年齡),課程的關(guān)系模式為:課程(課號(hào),課程名,學(xué)時(shí)),其中兩個(gè)關(guān)系模式的鍵分別是學(xué)好和課號(hào),則關(guān)系模式選課可以定義為:選課(學(xué)號(hào),
【5】
,成績(jī))。(6)設(shè)x為int型變量,請(qǐng)寫出一個(gè)關(guān)系表達(dá)式
【6】
,用以判斷x同時(shí)為3和7的倍數(shù)時(shí),關(guān)系表達(dá)式的值為真。(7)有以下程序#include<stdio.h>main(){inta=1,b=2,c=3,d=0;if(a==1)
if(b!=2)
if(c!=3)
d=1;
else
d=2;
elseif(c!=3)
d=3;
else
d=4;
else
d=5;
printf("%d\n",d);}程序運(yùn)行后的輸出結(jié)果是:
【7】
。(8)有以下程序#include<stdio.h>main(){
intm,n;scanf("%d%d",&m,&n);while(m!=n){
while(m>n)m=m-n;
while(m<n)n=n-m;}printf("%d\n",m);}程序運(yùn)行后,當(dāng)輸入14
63<回車>時(shí),輸出結(jié)果是
【8】
(9)有以下程序#include<stdio.h>main(){
intI,j,a[][3]={1,2,3,4,5,6,7,8,9};
for(i=1;i<3;i++)
for(j=I;j<3;j++)
printtf("%d",a[i][j]);
printf("\n");}程序運(yùn)行后的輸出結(jié)果是
【9】
(10)有以下程序
#include<stdio.h>main(){
int
[]={1,2,3,4,5,6},*k[3],i=0;
while(i<3)
{
k[i]=&a[2*i];
printf("%d",*k[i]);
i++;
}}程序運(yùn)行后的輸出結(jié)果是__________(11)有以下程序
#include<stdio.h>main(){
int
a[3][3]={{1,2,3},{4,5,6},{7,8,9}};
int
b[3]={0},i;
for(i=0;i<3;i++)b[i]=a[i][2]+a[2][i];
for(i=0;i<3;i++)printf("%d",b[i]);
printf("\n");}程序運(yùn)行后的結(jié)果是____________(12)有以下程序#include<stdio.h>#include<string.h>voidfun(char*str){
chartemp;
intn,i;
n=strlen(str);
temp=str[n-1];
for(i=n-1;i>0;i--)str[i]=str[i-1];
str[0]=temp;}main(){
chars[50];
scanf("%s",s);
fun(s);
printf("%s\n",s);}程序運(yùn)行后輸入:abcdef<回車>,則輸出結(jié)果是____________(13)以下程序的功能是:將值為三位正整數(shù)的變量x中的數(shù)值按照個(gè)位、十位、百位的順序拆分并輸出。請(qǐng)?zhí)羁铡?include<stdio.h>main(){
intx=256;
printf("%d-%d-%d\n",
,x/10%10,x/100);}
(14)以下程序用以刪除字符串中的所有的空格,請(qǐng)?zhí)羁铡?include<stdio.h>main(){
char
s[100]={"our.tercherteach
clanguage!"};inti,j;for(i=j=0;s[i]!=‘\0’;i++)
if(s[i]!=‘’){s[j]=s[i];j++;}s[j]=
;printf("%s\n",s);}
(15)以下程序功能是:借助指針變量找出數(shù)組元素中的最大值及其元素的下標(biāo)值。請(qǐng)?zhí)羁铡?include<stdio.h>main(){
inta[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=_______________;
printf("index=%d\n",s-a);}
參考答案
一、選擇題:1-5ADBAC
6-10BADCA
11-15BBDCC
16-20DABCA
21-25DDABD
26-30ADBCC
31-35ACBCC
36-40BADAC二、填空題1、ABCDEF543212、153、EDBGHFCA4、程序5、課號(hào)6、(x%3==0)&&(x%7==0)7、48、79、12356910、13511、10141812、fabcde13、x%1014、'\0'或者填寫015、p2010年9月全國計(jì)算機(jī)二級(jí)C語言筆試試題一、選擇題(每小題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)上述三種說法都不對(duì)
(2)下列敘述中正確的是
A)在棧中,棧中元素隨棧底指針與棧頂指針的變化而動(dòng)態(tài)變化
B)在棧中,棧頂指針不變,棧中元素隨棧底指針的變化而動(dòng)態(tài)變化
C)在棧中,棧底指針不變,棧中元素隨棧頂指針的變化而動(dòng)態(tài)變化
D)上述三種說法都不對(duì)
(3)軟件測(cè)試的目的是
A)評(píng)估軟件可靠性
B)發(fā)現(xiàn)并改正程序中的錯(cuò)誤
C)改正程序中的錯(cuò)誤
D)發(fā)現(xiàn)程序中的錯(cuò)誤
(4)下面描述中,不屬于軟件危機(jī)表現(xiàn)的是
A)軟件過程不規(guī)范
B)軟件開發(fā)生產(chǎn)率低
C)軟件質(zhì)量難以控制
D)軟件成本不斷提高
(5)軟件生命周期是指
A)軟件產(chǎn)品從提出、實(shí)現(xiàn)、使用維護(hù)到停止使用退役的過程
B)軟件從需求分析、設(shè)計(jì)、實(shí)現(xiàn)到測(cè)試完成的過程
C)軟件的開發(fā)過程
D)軟件的運(yùn)行維護(hù)過程(6)面向?qū)ο蠓椒ㄖ校^承是指
A)一組對(duì)象所具有的相似性質(zhì)
B)一個(gè)對(duì)象具有另一個(gè)對(duì)象的性質(zhì)
C)各對(duì)象之間的共同性質(zhì)
D)類之間共享屬性和操作的機(jī)制
(7)層次型、網(wǎng)狀型和關(guān)系型數(shù)據(jù)庫劃分原則是
A)記錄長(zhǎng)度
B)文
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 銀行貸款展期還款合同
- 購銷合同范本設(shè)計(jì)范本
- 聘用合同補(bǔ)充協(xié)議的簽訂與監(jiān)管要求
- 賓館設(shè)施完善保證
- 信息系統(tǒng)建設(shè)項(xiàng)目實(shí)施合同
- 廣告牌吊裝作業(yè)
- 個(gè)人信用借款合同格式樣本
- 房屋買賣合同范本模板樣本示例
- 售后服務(wù)協(xié)議簽訂糾紛解決
- 全方位集成服務(wù)合同模板
- 有效的雙向溝通管理制度
- 圍棋協(xié)會(huì)2022年工作計(jì)劃范文
- 07講信息系統(tǒng)建設(shè)和設(shè)計(jì)軟件工程
- 廁所蹲位統(tǒng)計(jì)表10
- OptiXOSN8800產(chǎn)品系統(tǒng)硬件系統(tǒng)、單板介紹
- 附件1黑龍江省事業(yè)單位聘用合同制管理辦法doc
- 蔬菜大棚溫度控制器設(shè)計(jì)(共20頁)
- LS-MASTER-K-指令手冊(cè)
- 烏茲別克語字母表
- 《數(shù)據(jù)結(jié)構(gòu)》課程標(biāo)準(zhǔn)
- 畢業(yè)設(shè)計(jì)(論文)基于單片機(jī)AT89C51的數(shù)字搶答器設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論